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(57) Abstract 

A method and apparatus for processing cochannel sig- 
nals received at a sensor array (110) in a cumulant-based 
signal processing and separation engine to obtain a desired 
set of output signals (38) or parameters. For use in a sig- 
nal recovery system, the output signals are recovered and 
separated versions of the originally transmitted cochannel 
signals. An important feature that distinguishes the cumu- 
lant-based system from other signal separation and recov- 
ery systems is that it generates an estimated generalized 
steering vector associated with each signal source, and rep- 
resentative of all received coherent signal components at- 
tributable to the source. This feature enables the invention 
to perform well in multipath conditions, by combining all 
coherent multipath components from the same source. In 
a receiver/transmitter system (316), the estimated general- 
ized steering vectors associated with each source are used 
to generate transmit beamformer weight vectors that permit 
cochannel transmission to multiple user stations (310). The 
basic cumulant-based processing and separation engine can 
also be used in a variety of applications, such as high den- 
sity recording, complex phase angle equalization, receiving 
systems with enhanced effective dynamic range, and signal 
separation in the presence of strong interference. Various 
embodiments and extensions of the basic cumulant-based 
system are disclosed. 
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COCHANNEL SIGNAL PROCESSING SYSTEM 
BACKGROUND OF THE INVENTION 

5 1. Field of the Invention 

This invention relates generally to signal processing systems and, more 
particularly, to apparatus and methods for receiving and processing signals that share a 
common receiver frequency band at the same time, referred to as cochannel signals. 
Even two signals transmitted on slightly separated frequency bands may be 
10 "cochannel" signals as seen by a receiver operating to receive signals on a bandwidth 
that overlaps both of the signals. In a variety of signal processing applications, there is 
a need to recover information contained in such multiple, simultaneously received 
signals. In the context of this invention, the word "recover" or "recovery" 
encompasses separation of the received signals, "copying" the signals (i.e., retrieving 
15 any information contained in them), and, in some applications, combining signals 
received over multiple paths from a single source. The "signals" may be 
electromagnetic signals transmitted in the atmosphere or in space, acoustic signals 
transmitted through liquids or solids, or other types of signals characterized by a time- 
varying parameter, such as the amplitude of a wave. In accordance with another aspect 
20 of the invention, signal processing includes transmission of cochannel signals. 

In the environment of the present invention, signals are received by 
"sensors." A sensor is an appropriately selected transducer for converting energy 
contained in the signal to a more easily manipulated form, such as electrical energy. In 
a radio communications application, electromagnetic signals are received by antennas 
25 and converted to electrical signals for further processing. After separation of the 
signals, they may be forwarded separately to transducers of a different type, such as 
loudspeakers, for converting the separated electrical signals into audio signals. In some 
applications, the signal content may be of less importance than the directions from 
which the signals were received, and in other applications the received signals may not 
30 be amenable to conversion to audible form. Instead, each recovered signal may contain 
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information in digital form, or may contain information that is best understood by 
displaying it on a chart or electronic display device. Regardless of the environment in 
which the present invention is employed, it is characterized by multiple signals 
received by sensors simultaneously at the same or overlapping frequencies, the need to 
5 separate, recover, identify or combine the signals and, optionally, some type of output 
transducer to put the recovered information in a more easily discernible form. 

2. Description of Related Art 

Separation and recovery of signals of different frequencies is a routine 

10 matter and is handled by appropriate filtering of the received signals. It is common 
knowledge that television and radio signals are transmitted on different frequency 
bands and that one may select a desired signal by tuning a receiver to a specific 
channel. Separation and recovery of multiple signals transmitted at different 
frequencies and received simultaneously may be effected by similar means, using 

15 multiple tuned receivers in parallel. A more difficult problem, and the one with which 
the present invention is concerned, is how to separate and copy signals from multiple 
sources when the transmitted signals are at the same or overlapping frequencies. A 
single sensor, such as an antenna, is unable to distinguish between two or more 
received signals at the same frequency. However, antenna array technology provides 

20 for the separation of signals received from different directions. Basically, and as is well 
understood by antenna designers, an antenna array can be electronically "steered" to 
transmit or receive signals to or from a desired direction. Moreover, the characteristics 
of the antenna array can be selectively modified to present "nulls" in the directions of 
signals other than that of the signal of interest. A further development in the processing 

25 of array signals was the addition of a control system to steer the array toward a signal 
of interest. This feature is called adaptive array processing and has been known for at 
least two to three decades. See, for example, a paper by B. Widrow, P.E. Mantey, 
L.J. Griffiths and B.B. Goode, "Adaptive Antenna Systems," Proceedings of the 
IEEE, vol. 55, no. 12, pp. 2143-2159, December 1967. The steering characteristics of 
30 the antenna can be rapidly switched to receive signals from multiple directions in a 
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" time-sliced" manner. At one instant the antenna array is receiving a signal from one 
source and at the next instant, from a different source in a different direction, but 
information from the multiple sources is sampled rapidly enough to provide a complete 
record of all the received signals. It will be understood that, although steered antenna 

5 array technology was developed principally in the communications and radar fields, it 
is also applicable to the separation of acoustic and other types of signals. 

In the communications field, signals take a variety of forms. Stated most 
generally, a communication signal typically includes a carrier signal at a selected 
frequency, on which is impressed or modulated an information signal. There are a 

10 large number of different modulation schemes, including amplitude modulation, in 
which the amplitude of the signal is varied in accordance with the value of an 
information signal, while the frequency stays constant, and frequency or phase 
modulation, in which the amplitude of the signal stays constant while its frequency or 
phase is varied to encode the information signal onto the carrier. Various forms of 

15 frequency and phase modulation are often referred to as constant modulus modulation 
methods, because the amplitude or modulus of the signal remains constant, at least in 
theory. In practice, the modulus is subject to distortion during transmission, and 
various devices, such as adaptive equalizers, are used to restore the constant-modulus 
characteristic of the signal at a receiver. The constant modulus algorithm was 

20 developed for this purpose and later applied to antenna arrays in a process called 
adaptive beam forming The following references are provided by way for further 
background on the constant modulus algorithm: 

B. Agee, "The least-squares CM A: a new technique for rapid correction 
of constant modulus signals," Proc. ICASSP-86, pp. 953-956, Tokyo, Japan, April 

25 1986. 

R. Gooch, and J. Lundell, "The CM array, an adaptive beamformer for 
constant modulus signals," Proc. ICASSP-86, pp. 2523-2526, Tokyo, Japan, April 
1986. 

J. Lundell, and B. Widrow, "Applications of the constant modulus 
30 adaptive algorithm to constant and non-constant modulus signals," Proc. Twenty- 
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Second Asilomar Conference on Signals, Systems, and Computers, pp. 432-436, Pacific 
Grove, CA, November 1988. 

B.G. Agee, "Blind separation and capture of communication signals 
using a multi-target constant modulus beamformer," Proc. 1989 IEEE Military 
5 Communications Conference, pp. 340-346, Boston, MA, October 1989. 

R.D. Hughes, E.H. Lawrence, and L.P. Withers, Jr., "A robust 
adaptive array for multiple narrowband sources," Proc. Twenty-Sixth Asilomar 
Conference on Signals, Systems, and Computers, pp. 35-39, Pacific Grove, CA, 
November 1992. 

10 J.J. Shynk and R.P. Gooch, "Convergence properties of the multistage 

CM A adaptive beamformer," Proc. Twenty-Seventh Asilomar Conference on Signals, 
Systems, and Computers, pp. 622-626, Pacific Grove, CA, November 1993. 

The constant modulus algorithm works satisfactorily only for constant 
modulus signals, such as frequency-modulated (FM) signals or various forms of phase- 

15 shift keying (PSK) in which the phase is discretely or continuously varied to represent 
an information signal, but not for amplitude-modulated (AM) signals or modulation 
schemes that employ a combination of amplitude and phase modulation. There is a 
significant class of modulation schemes used known as M-ary quadrature amplitude 
modulation (QAM), used for transmitting digital data, whereby the instantaneous phase 

20 and amplitude of the carrier signal represents a selected data state. For example, 16-ary 
QAM has sixteen distinct phase-amplitude combinations. The "signal constellation" 
diagram for such a scheme has sixteen points arranged in a square matrix and lying on 
three separate constant-modulus circles. A signal constellation diagram is a convenient 
way of depicting all the possible signal states of a digitally modulated signal. In such a 

25 diagram, phase is represented by angular position and modulus is represented by 
distance from an origin. 

The constant modulus algorithm has been applied with limited success to 
a 16-ary QAM scheme, because it can be represented as three separate constant- 
modulus signal constellations. However, for higher orders of QAM the constant 

30 modulus algorithm provides rapidly decreasing accuracy. For suppressed-carrier AM, 
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the constant modulus approach fails completely in trying to recover cochannel AM 
signals. If there are multiple signals, the constant modulus algorithm yields signals 
with "cross-talk," i.e. with information in the two signals being confused. For a single 
AM signal in the presence of noise, the constant-modulus algorithm yields a relatively 
5 noisy signal. 

Because antenna arrays can be steered electronically to determine the 
directions of signal sources, it was perhaps not surprising that one well known form 
signal separator available prior to the present invention used direction finding as its 
basis. The approach is referred to as DF-aided copy, where DF means direction 

10 finding. This is an open-loop technique in which steering vectors that correspond to 
estimated signal source bearings are first determined; then used to extract waveforms 
of received signals. However, the direction finding phase of this approach requires a 
knowledge of the geometry and performance characteristics of the antenna array. Then 
steering vectors are fed forward to a beamformer, which nulls out the unwanted signals 

15 and steers one or more antenna beam(s) toward each selected source. 

Prior to the present invention, some systems for cochannel signal 
separation used direction-finding (DF)-beamforming. Such systems separate cochannel 
signals by means of a multi-source (or cochannel) super-resolution direction finding 
algorithm that determines steering vectors and directions of arrival (DOAs) of multiple 

20 simultaneously detected cochannel signal sources. An algorithm determines beam- 
forming weight vectors from the set of steering vectors of the detected signals. The 
beamforming weight vectors are then used to recover the signals. Any of several well- 
known multi-source super-resolution DF algorithms can be used in such a system. 
Some of the better known ones are usually referred to by the acronyms MUSIC 

25 (Multiple Signal Classification), ESPRIT (Estimation of Signal Parameters via 
Rotational Invariance Techniques), Weighted Subspace Fitting (WSF), and Method of 
Direction Estimation (MODE). 

MUSIC was developed in 1979 simultaneously by Ralph Schmidt in the 
United States and by Georges Bienvenu and Lawrence Kopp in France. The Schmidt 
30 work is described in R.O. Schmidt, "Multiple emitter location and signal parameter 
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estimation," Proc. RADC Spectrum Estimation Workshop, pp. 243-258, Rome Air 
Development Center, Griffiss Air Force Base, NY, October 3-5, 1979. The Bienvenu 
work is described in G. Bienvenu and L. Kopp, "Principe de la goniometrie passive 
adaptative," Proc. Colloque GRETSI, pp. 106/1-106/10, Nice, France, May 1979. 

5 MUSIC has been extensively studied and is the standard against which other super- 
resolution DF algorithms are compared. 

ESPRIT is described in many publications in the engineering signal 
processing literature and is the subject of United States Patent No. 4,750,147 entitled 
"Method for estimating signal source locations and signal parameters using an array of 

10 sensor pairs," issued to R.H. Roy III et al. ESPRIT was developed by Richard Roy, 
III, Arogyaswami Paulraj, and Prof. Thomas Kailath at Stanford University. It was 
presented as a super-resolution algorithm for direction finding in the following series of 
publications starting in 1986: 

A. Paulraj, R. Roy, and T. Kailath, "A subspace rotation approach to 
15 signal parameter estimation," Proc. IEEE, vol. 74, no. 4, pp. 1044-1045, July 1986. 

R. Roy, A. Paulraj, and T. Kailath, "ESPRIT - A subspace rotation 
approach to estimation of parameters of cisoids in noise," IEEE Trans. Acoust., 
Speech, and Signal Processing, vol. ASSP-34, no. 5, pp. 1340-1342, October 1986. 

R.H. Roy, ESPRIT - Estimation of Signal Parameters via Rotational 
20 Invariance Techniques, doctoral dissertation, Stanford University, Stanford, CA, 1987. 

R. Roy and T. Kailath, "ESPRIT - Estimation of signal parameters via 
rotational invariance techniques," IEEE Trans. Acoust., Speech, and Signal 
Processing, vol. ASSP-37, no. 7, pp. 984-995, July 1989. 

B. Ottersten, R. Roy, and T. Kailath, "Signal waveform estimation in 
25 sensor array processing," Proc. Twenty-Third Asilomar Conference on Signals, 

Systems, and Computers, pp. 787-791, Pacific Grove, CA, November 1989. 

R. Roy and T. Kailath, "ESPRIT - Estimation of signal parameters via 
rotational invariance techniques," Optical Engineering, vol. 29, no. 4, pp. 296-313, 
April 1990. 



WO 98/24192 



PCT/US96/18867 



-7- 

MUSIC and ESPRIT both require the same "narrowband array 
assumption," which is further discussed below in the detailed description of the 
invention, and both are modulation independent, a feature shared by all cochannel 
signal separation and recovery techniques that are based on the DF-beamforming 
5 method. 

ESPRIT calculates two N-by-N covariance matrices, where N is the 
number of antenna elements, and solves a generalized eigenvalue problem numerically 
(instead of using a calibration table search, as MUSIC does). It does this for every 
block of input samples. MUSIC calculates a single N-by-N covariance matrix, 
10 performs an eigendecomposition, and searches a calibration table on every block of 
input array samples (snapshots). 

MUSIC and ESPRIT have a number of shortcomings, some of which are 
discussed in the following paragraphs. 

ESPRIT was successfully marketed based on a single, key advantage 
15 over MUSIC. Unlike MUSIC, ESPRIT did not require array calibration. In ESPRIT, 
the array calibration requirement was eliminated, and a different requirement on the 
antenna array was substituted. The new requirement was that the array must have a 
certain geometrical property. Specifically the array must consist of two identical sub- 
arrays, one of which is offset from the other by a known displacement vector. In 
20 addition, ESPRIT makes the assumption that the phases of received signals at one sub- 
array are related to the phases at the other sub-array in an ideal theoretical way. 

Another significant disadvantage of ESPRIT is that, although it purports 
not to use array calibration, it has an array manifold assumption hidden in the 
theoretical phase relation between sub-arrays. "Array manifold" is a term used in 
25 antenna design to refer to a multiplicity of physical antenna parameters that, broadly 
speaking, define the performance characteristics of the array. 

A well known difficulty with communication systems, especially in an 
urban environment, is that signals from a single source may be received over multiple 
paths that include reflections from buildings and other objects. The multiple paths may 
30 interpose different time delays, phase changes and amplitude changes on the 



WO 98/24192 



PCT7US96/18867 



transmitted signals, rendering reception more difficult, and transmission uncertain. 
This difficulty is referred to as the multipath problem. It is one that has not been 
adequately addressed by signal processing systems of the prior art. 

Neither MUSIC nor ESPRIT can operate in a coherent multipath 

5 environment without major added complexity. A related problem is that, in a signal 
environment devoid of coherent multipath, no DF-beamforming method can separate 
signals from sources that are collinear with the receiving array, i.e. signal sources that 
are in line with the array and have zero angular separation. Even in a coherent 
multipath environment, DF-beamforming methods like MUSIC and ESPRIT cannot 

10 separate and recover cochannel signals from collinear sources. 

Another difficulty with ESPRIT is that it requires two antenna sub- 
arrays and is highly sensitive to mechanical positioning of the two sub-arrays, and to 
the electromagnetic matching of each antenna in one sub-array with its counterpart in 
the other sub-array. Also ESPRIT requires a 2N-channel receiver, where N is the 

15 number of antenna elements, and is highly sensitive to channel matching. 

Another significant drawback in both MUSIC and ESPRIT is that they 
fail abruptly when the number of signals detected exceeds the capacity, N, equal to the 
number of antennas in the case of MUSIC, or half the number of antennas in the case 
of ESPRIT. 

20 A fundamental problem with both MUSIC and ESPRIT is that they use 

open-loop feed-forward computations, in which errors in the determined steering 
vectors are uncorrected, uncorrectable, and propagate into subsequent calculations. As 
a consequence of the resultant inaccurate steering vectors, MUSIC and ESPRIT have 
poorcross-talk rejection, as measured by signal-to-interference-plus-noise ratio (SINR) 

25 at the signal recovery output ports. 

ESPRIT is best suited to ground based systems where its antenna 
requirements are best met and significant computational resources are available. 
MUSIC has simpler antenna array requirements and lends itself to a wider range of 
platforms, but also needs significant computational resources. 



WO 98/24192 



PCT/US96/18867 



Another limitation of most signal recovery systems of the prior art is 
that they rely on first-order and second-order statistical moments of the received signal 
data. A moment is simply a statistical quantity derived from the original data by 
mathematical processing at some level. An average or mean value of the several signals 
5 received at a given time is an example of a first-order moment. The average of the 
squares of the signal values (proportional to signal powers) is an example of a second- 
order moment. Even if one considers just one signal and a noise component, computing 
the average of the sum of the squares produces a cross-term involving the product of 
signal and noise components. Typically, engineers have managed to find a way to 
10 ignore the cross-term by assuming that the signal and the noise components are 
statistically independent. At a third-order level of statistics, one has to assume that the 
signal and noise components have zero mean values in order to eliminate the cross- 
terms in the third-order moment. For the fourth-order and above, the computations 
become very complex and are not easily simplified by assumptions. In most prior art 
15 signal analysis systems, engineers have made the gross assumption that the nature of all 
signals is Gaussian and that there is no useful information in the higher-order moments. 
Higher-order statistics have been long recognized in other fields and there is recent 
literature suggesting their usefulness in signal recovery. Prior to this invention, 
cumulant-based solutions have been proposed to address the "blind" signal separation 
20 problem, i.e. the challenge to recover cochannel signals without knowledge of antenna 
array geometry or calibration data. See, for example, the following references: 

J.-F. Cardoso, "Source separation using higher order moments," Proc. 
ICASSP-89, pp. 2109-2112, Glasgow, Scotland, May 1989. 

J.-F. Cardoso, "Eigen-structure of the fourth-order cumulant tensor with 
25 application to the blind source separation problem," Proc. ICASSP-90, pp. 2655-2658, 
Albuquerque, New Mexico, April 1990. 

J.-F. Cardoso, "Super-symmetric decomposition of the fourth-order 
cumulant tensor: blind identification of more sources than sensors," Proc. ICASSP-91, 
pp. 3109-3112, Toronto, Canada, May 1991. 
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J.-F. Cardoso, "Higher-order narrowband array processing," 
International Signal Processing Workshop on Higher Order Statistics, pp. 121—130, 
Chamrousse-France, July 10-12, 1991. 

J.-F. Cardoso, "Blind beamforming for non-Gaussian sources," IEE 
5 Proceedings Part F, vol. 140, no. 6, pp. 362--370, December 1993. 

P. Comon, "Separation of stochastic processes, " Proc. Vail Workshop 
on Higher-Order Spectral Analysis, pp. 174-179, Vail, Colorado, USA, June 1989. 

P. Comon, "Independent component analysis," Proc. of Intl. Workshop 
on Higher-Order Statistics, pp. 111-120, Chamrousse, France, 1991. 
10 P. Comon, C. Jutten, and J. Herault, "Blind separation of sources, part 

II: problems statement," Signal Processing, vol. 24, no. 1, pp. 11-20, July 1991. 

E. Chaumette, P. Comon, and D. Muller, "ICA-based technique for 
radiating sources estimation: application to airport surveillance," IEE Proceedings Part 
F, vol. 140, no. 6, pp. 395-401, December 1993. 
15 Z. Ding, "A new algorithm for automatic beamforming," Proc. Twenty- 

Fifth Asilomar Conference on Signals, Systems, and Computers, pp. 689-693, Pacific 
Grove, CA, November 1991. 

M. Gaeta and J.-L. Lacoume, "Source separation without a-priori 
knowledge: the maximum likelihood solution," Proc. EUSIPCO, pp. 621-624, 1990. 
20 E. Moreau, and O. Macchi, "New self-adaptive algorithms for source 

separation based on contrast functions," Proc. IEEE SP Workshop on Higher-Order 
Statistics, pp. 215-219, Lake Tahoe, USA, June 1993. 

P. Ruiz, and J.L. Lacoume, "Extraction of independent sources from 
correlated inputs: a solution based on cumulants," Proc. Vail Workshop on Higher- 
25 Order Spectral Analysis , pp. 146-151, Vail, Colorado, USA, June 1989. 

E.H. Satorius, J.J. Mulligan, Norman E. Lay, "New criteria for blind 
adaptive arrays," Proc. Twenty -Seventh Asilomar Conference on Signals, Systems, and 
Computers, pp. 633-637, Pacific Grove, CA, November 1993. 
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L. Tong, R. Liu, V. Soon, and Y. Huang, "Indeterminacy and 
identifiability of blind identification," IEEE Trans. Circuits and Systems, vol. 38, pp. 
499-509, May 1991. 

L. Tong, Y. Inouye and R. Liu, "Waveform preserving blind estimation 
5 of multiple independent sources," IEEE Trans. Signal Processing, vol. 41, no. 7, pp. 
2461--2470, July 1993. 

However, all of these approaches to blind signal recovery address the 
static case in which a batch of data is given to a processor, which then determines the 
steering vectors and exact waveforms. These prior approaches do not have the ability 
10 to identify new sources that appear or existing sources that are turned off. In addition, 
previously proposed algorithms require multiple levels of eigendecomposition of array 
covariance and cumulant matrices. Their convergence to reliable solutions depends on 
the initialization and utilization of the cumulant matrices that can be derived from array 
measurements. Furthermore, previous cumulant-based algorithms have convergence 
15 problems in the case of identically modulated sources in general. 

Ideally, a system for receiving and processing multiple cochannel signals 
should make use of statistics of the measurements, and should not need to rely on 
knowledge of the geometry or array manifold of the sensors, i.e., the array calibration 
data. Also, the system should be able to receive and process cochannel signals 
20 regardless of their modulation or signal type, e.g. it should not be limited to constant- 
modulus signals. More generally, the ideal cochannel signal processing system should 
not be limited to any modulation properties, such as baud rate or exact center 
frequency. Any system that is limited by these properties has only a limited range of 
source types that can be separated, and is more suitable for interference suppression in 
25 situations where the desired signal properties are well known. Another desirable 
property of the ideal cochannel signal receiving and processing system is that it should 
operate in a dynamic way, identifying new signal sources that appear and identifying 
sources that disappear. Another desirable characteristic is a very high speed of 
operation allowing received signals to be processed in real time. As will shortly 
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become apparent, the present invention meets and exceeds these ideal characteristics 
for cochannel signal processing. 

SUMMARY OF THE INVENTION 

5 

The present invention resides in a system or method for processing 
cochannel signals received at a sensor array and producing desired recovered signals or 
parameters as outputs. In the context of this specification, "cochannel" signals are that 
overlap in frequency, as viewed from a receiver of the signals. Even signals that are 

10 transmitted in separate, but closely spaced, frequency bands may be cochannel signals 
as viewed from a receiver operating in bandwidth wide enough to overlap both of the 
signals. A key aspect of the invention is that it is capable of separating and recovering 
multiple cochannel signals very rapidly using only sensor array signals, without 
knowledge of sensor array geometry and array manifold, (e.g. array calibration data), 

15 and without regard to the signal type or modulation. If array calibration data are 
available, the system also provides direction-of-arrival parameters for each signal 
source. The invention inherently combines coherent multipath components of a 
received signal and as a result achieves improved performance in the presence of 
multipath. One embodiment of the invention also includes a transmitter, which makes 

20 use of estimated generalized steering vectors generated while separating and recovering 
received signals, in order to generate appropriate steering vectors for transmitted 
signals, to ensure that transmitted signals intended for a particular signal source 
traverse generally the same path or paths that were followed by signals received from 
the same signal source. 

25 Briefly, and in general terms, the system of the invention comprises a 

signal receiving system, including means for generating a set of conditioned receiver 
signals from cochannel signals of any modulation or type received at a sensor array 
from multiple sources that can vary in power and location; an estimated generalized 
steering vector (EGSV) generator, for computing for each source an EGSV that results 

30 in optimization of a utility function that depends on fourth or higher even-order 
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statistical cumulants derived from the received signals, the EGSV being indicative of a 
combination of signals received at the sensors from a signal source; and a supplemental 
computation module, for deriving output quantities of interest from the conditioned 
receiver signals and the EGSVs. 
5 The basic invention as described in the preceding paragraph employs 

one of three basic methods for computing EGSVs: two iterative methods and one direct 
computation method. In the first iterative method, the system includes a linear 
combiner, for repeatedly computing a single channel combined signal from the 
conditioned receiver signals and an EGSV; means for supplying an initial EGSV to the 
10 linear combiner, to produce the initial output of a single channel combined signal; an 
EGSV computation module, for computing successive values of the EGSV from 
successive values of the single channel combined signal received from the linear 
combiner and the conditioned receiver signals; and means for feeding the successive 
values of the EGSV back to the linear combiner for successive iteration cycles. Also 
15 included is means for terminating iterative operation upon convergence of the EGSV to 
a sufficiently accurate value. 

If the second iterative method is used, the system includes a cross- 
cumulant matrix computation module, for generating a matrix of cross-cumulants of all 
combinations of the conditioned receiver signals; a structured quadratic form 
20 computation module, for computing successive cumulant strength functions derived 
from successive EGSVs and the cross-cumulant matrix; means for supplying an initial 
EGSV to the structured quadratic form computation module, to produce the initial 
output of a cumulant strength function; an ESGV computation module, for generating 
successive EGSVs from successive cumulant strength functions received from the 
25 structured quadratic form computation module; means for feeding the successive 
values of the EGSV back to the structured quadratic form computation module for 
successive iteration cycles; and means for terminating iterative operation upon 
convergence of the EGSV to a sufficiently accurate value. 

Finally, if the direct computation method is used, the system includes a 
30 cross-cumulant matrix computation module, for generating a matrix of cross-cumulants 
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of all combinations of the conditioned receiver signals; and an EGSV computation 
module for computing the EGSV directly from the cross-cumulant matrix by solving a 
fourth degree polynomial equation. 

Regardless which of the foregoing variants is employed, signal 

5 processing may employ one of several different cumulant recovery (CURE) techniques. 
In a first of these techniques, the means for generating the set of conditioned signals 
includes a covariance matrix computation module, an eigendecomposition module for 
generating the eigenstructure of the covariance matrix and an estimate of the number of 
signal sources, and a transformation matrix for conditioning the receiver signals. An 

10 EGSV generator then employs signals output by the eigendecomposition module to 
compute EGSVs. This technique is referred to in this specification as the eigenCURE 
or eCURE system. 

An alternate processing technique uses covariance inversion of the 
received signals and is referred to as the CiCURE system. In this approach, the means 

15 for generating the set of conditioned signals includes a covariance matrix computation 
module and a matrix decomposition module, for generating the inverse covariance 
matrix and a transformation matrix for conditioning the receiver signals. An EGSV 
generator then employs signals output by the eigendecomposition module to compute 
EGSVs. The system further includes a beamformer, for generating a recovered signal 

20 from the receiver signals by using the EGSV(s) and the matrix obtained from the 
matrix decomposition module. 

Yet another processing technique is referred to as pipelined cumulant 
recovery, or pipeCURE. The means for generating the set of conditioned signals 
includes a covariance matrix computation module, an eigendecomposition module for 

25 generating an estimate of the number of signal sources, a transformation matrix for 
conditioning the receiver signals, and an eigenstructure derived from the receiver 
signals. Again, the EGSV generator employs signals output by the eigendecomposition 
module to compute EGSVs. Processing is on a block-by-block basis, and the system 
further comprises a multiple port signal recovery unit, including means for matching 
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current EGSVs with EGSVs from a prior data block to impose waveform continuity 
from block to block. 

Another variant that can be used in any of these processing techniques 
involves the manner in which initial EGSVs are computed at the start of processing a 

5 new block of data. In accordance with this aspect of the invention, the initial values of 
EGSVs for each new processing block are computed by combining a prior block EGSV 
and a cumulant vector derived from the utility function used in the EGSV generator. 
More specifically, the means for combining takes the sum of the prior block EGSV 
multiplied by a first factor, and the cumulant vector multiplied by a second factor. The 

10 first and second factors may be selected to provide an initial EGSV that anticipates and 
compensates for movement of a signal source. 

In a practical embodiment of the invention, the system functions to 
separate a plurality (P) of received cochannel signals. If the first iterative method is 
employed, there are multiple EGSV generators (P in number), including P EGSV 

15 computation modules and P linear combiners, for generating an equal plurality (P) of 
EGSVs associated with P signal sources. The supplemental computation module 
functions to recover P separate received signals from the P generalized steering vectors 
and the conditioned receiver signals. More specifically, the supplemental computation 
module includes a recovery beamformer weight vector computation module, for 

20 generating from all of the EGSVs a plurality (P) of receive weight vectors, and a 
plurality (P) of recovery beamformers, each coupled to receive one of the P receive 
weight vectors and the conditioned receiver signals, for generating a plurality (P) of 
recovered signals. 

For recovery of multiple signals using the second iterative method, there 
25 is a plurality (P) of EGSV generators, including P EGSV computation modules and P 
structured quadratic form computation modules, for generating an equal plurality (P) of 
EGSVs associated with P signal sources. Again, the supplemental computation module 
includes a recovery beamformer weight vector computation module, for generating 
from all of the EGSVs a plurality (P) of receive weight vectors, and a plurality (P) of 
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recovery beamformers, each coupled to receive one of the P receive weight vectors and 
the conditioned receiver signals, for generating a plurality (P) of recovered signals. 

If the direct processing method is used to separate two signals, the 
ESGV computation module generates two EGSVs from the cross-cumulant matrix data; 

5 and the supplemental computation module functions to recover two separate received 
signals from the two generalized steering vectors and the conditioned receiver signals. 
The supplemental computation module includes a recovery beamformer weight vector 
computation module, for generating from both of the EGSVs two receive weight 
vectors, and two recovery beamformers, each coupled to receive one of the receive 

10 weight vectors and the conditioned receiver signals, for generating two recovered 
signals. 

Although the system of the invention operates in a "blind" sense, 
without knowledge of the geometry or calibration data of the sensor array, it will also 
function as a direction finder if array calibration data are available. Hence, in one 
15 embodiment of the invention, the system functions to derive the direction of arrival 
(DO A) of a received signal; and the supplemental computation module includes a 
memory for storing sensor array calibration data, and means for deriving the DOA of a 
received signal from its associated steering vector and the stored sensor array 
calibration data. More specifically, the sensor array calibration data includes a table 
20 associating multiple DOA values with corresponding steering vectors; and the means 
for deriving the DOA includes means for performing a reverse table lookup function to 
obtain an approximated DOA value from a steering vector supplied by the generalized 
steering vector generator. The means for deriving the DOA may also include means for 
interpolating between two DOA values to obtain a more accurate result. 
25 In another important embodiment of the invention, the supplemental 

computation module of the signal processing system also includes a transmitter, for 
generating transmit signal beamformer weights from the received signal beamformer 
weights, and for transmitting signals containing information in a direction determined 
by the transmit signal beamformer weights. 
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Other aspects of the invention pertain to various application of the basic 
cumulant recovery (CURE) signal processing engine described above. Some of these 
applications are summarized in the following paragraphs. 

An important application of the invention is in two-way radio 
5 communication. Because CURE processing generates an estimated generalized steering 
vector not necessarily for each received signal, but for each signal source, the 
invention provides an important benefit when used in multipath conditions. Signals 
reaching a receiving antenna array over multiple paths will be combined in the CURE 
system if the received components are coherent, and the resultant generalized steering 
10 vector represents the combined effect of all the coherent multipath signals received at 
the antenna. This feature has a number of advantages. First, a radio receiving system 
using the CURE system is inherently immune to multipath problems encountered by 
conventional receivers. Second, by using generalized steering vectors, there can be an 
associated generalized null in the antenna directivity pattern, which can be used to null 
15 out an interfering signal having multipath structure in favor of a cochannel signal from 
another source. Third, the signal recovery method provides a diversity gain in the 
presence of multipath components, such that a stronger combined signal is received as 
compared with a system that discards all but one component. Fourth, the generalized 
steering vector concept allows multiple cochannel signals to be received and 
20 transmitted in the presence of multipath effects. Fifth, cochannel signal sources that are 
collinear with the receiver sensor array can be received and separated if there are 
multipath components. 

In another aspect of the invention, the CURE signal separation system 
can be used to separate signals transmitted in different modes over a "waveguide," by 
25 which is meant any bounded propagation medium, such as a microwave waveguide, an 
optical waveguide, a coaxial cable, or even a twisted pair of conductors. Although the 
transmission modes may become mixed in the waveguide, the original signals are 
easily recovered in the CURE system. 

In still another aspect of the invention, the CURE signal separation 
30 system can be used to separate signals recorded on closely space tracks on a recording 
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medium. Crosstalk between the signals on adjacent tracks is eliminated by using the 

CURE system to effect recovery. 

In yet another aspect of the invention, the CURE signal separation 

system can be used to extend the effective dynamic range of a receiver system. 
5 In a further aspect of the invention, the CURE signal separation system 

can be used to perform a complex phase equalization function automatically, without 

knowledge of the amount of phase correction that is needed. 

The CURE system may be modified to compensate for moving signal 

sources, and may also be modified to handle a wideband signal separation problem. 
10 The wideband signal separator includes multiple narrowband CURE systems, means 

for decomposing a wide band of signals into multiple narrowbands for processing, and 

means for combining the narrow bands again. 

Other aspects and advantages of the invention will become apparent 

from the following more detailed description, taken together with the accompanying 
15 drawings. 

BRIEF DESCRIPTION OF THE DRAWINGS 

FIG. 1 is a taxonomy diagram depicting the interrelationships of the 
20 invention's various cochannel signal processing methods. 

FIG. 2 A is a block diagram of the cumulant recovery (CURE) system of 
the invention in general form, depicting a first iterative method. 

FIG. 2B is a block diagram similar to FIG. 2A, but depicting a second 
iterative method. 

25 FIG. 2C is a block diagram similar to FIG. 2A, depicting a direct 

computation method. 

FIG. 3 A is a block diagram similar to FIG. 2A, but modified to depict 
how the invention functions to separate multiple received cochannel signals. 

FIG. 3B is a block diagram similar to FIG. 3A, but depicting the first 
30 iterative method. 
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FIG. 3C is a block diagram similar to FIG. 3A, but depicting the direct 
computation method. 

FIG. 4 A, is a block diagram of a supplemental computation module for 
signal recovery, shown in FIGS. 3A, 3B and 3C. 
5 FIG. 4B is a block diagram of a supplemental computation module for 

use in conjunction with the system of FIGS. 2A, 2B or 2C, to provide a direction 
finding function. 

FIG. 5 is a block diagram similar to FIG. 2A, but modified to depict a 
receiver/transmitter function. 
10 FIG. 6 is a block diagram similar to FIG. 3A, but modified to show 

input of signals from a signal "waveguide." 

FIG. 7 is a block diagram showing in more detail the functions 
performed in accordance with the two iterative methods for cochannel signal separation 
and .recovery. 

15 FIG. 8 A is simplified block diagram of a cochannel signal recovery 

system in accordance with the present invention. 

FIG. 8B is a hardware block diagram similar to FIG. 8A, of one 
preferred embodiment of the invention. 

FIG. 9 (comprising FIGS. 9A and 9B) is another block diagram of the 
20 system of FIG. 7, with some of the subsystem functions recited in each of the blocks. 

FIG. 10 is a block diagram of the preprocessor computer of FIG. 7. 
FIG. 11 (comprising FIGS. 11A and 11B) is a block diagram of a signal 
extraction port in an active state. 

FIG. 12 is a block diagram of the multiple port recovery unit of FIG. 9, 
25 including multiple signal extraction ports and an orthogonalizer. 

FIG. 13 (comprising FIGS. 13A, 13B and 13C) is a block diagram of 
the signal recovery controller of FIG. 7. 

FIG. 14 is a block diagram of a signal extraction port in the inactive 

state. 
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FIG. 15 is a block diagram of signal recovery system using covariance 
inversion cumulant recovery (CiCURE). 

FIG. 16 is a block diagram of a signal extraction port in the active state 
using the CiCURE system illustrated in FIG. 15. 
5 FIG. 17 is a block diagram of an alternate embodiment of the invention 

referred to as pipeCURE. 

FIG. 18 is a schematic diagram depicting a processing difficulty 
associated with moving signal sources. 

FIGS. 19 and 20 are vector diagrams depicting the effect of using 
10 a-pCURE and uCURE updating to initialize a block of samples for eCURE processing 
in the moving source situation such as shown in FIG. 18. 

FIG. 21 is a schematic diagram showing an overload condition in which 
there are more signal sources that antenna elements. 

FIG. 22 is a diagram of an antenna array directivity pattern for handling 
15 the situation shown in FIG. 21. 

FIG. 23 is a schematic diagram depicting multipath propagation paths 
from a transmitter to a receiver array. 

FIG. 24 is a schematic diagram depicting how the system of the 
invention handles coherent multipath signals in the presence of interference. 
20 FIG. 25 is a schematic diagram depicting how the system of the 

invention handles non-coherent multipath signals in the presence of interference. 

FIG. 26 is a schematic diagram depicting how the system of the 
invention handles receiving a desired signal in the presence of an interference signal 
with multipath components and a second interference source. 
25 FIG. 27 is a schematic diagram depicting the invention as used in the 

recovery of a received signal in the presence of a strong local transmitter. 

FIG. 28 is a schematic diagram depicting the invention as used in the 
recovery of a weak received signal in the presence of a strong jamming signal located 
nearby. 
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FIG. 29 is a schematic diagram depicting portions of a cellular telephone 
communication system of the prior art. 

FIG. 30 is a schematic diagram depicting how a communication system 
of the prior art separates cochannel signals. 
5 FIG. 31 is a schematic diagram depicting how the present invention 

operates in the environment of a cellular telephone communication system. 

FIG. 32 is a block diagram showing major portions of a transmitter as 
used in conjunction with the system of the present invention. 

FIG. 33 is a block diagram showing a transmitter similar to the one in 
io FIG. 32, but with more detail of some aspects of the apparatus. 

FIGS. 34A and 34B are diagrams depicting operation of the invention in 
recovery of dual-polarized signals. 

FIG. 35 is a schematic diagram depicting the invention as used in 
conjunction with an optical fiber network. 
15 FIG. 36 is a schematic diagram depicting the invention as used in copy- 

aided direction finding. 

FIG. 37 is a schematic diagram depicting the invention as used in 
extending the dynamic range of a receiver. 

FIG. 38 is a schematic diagram depicting the invention as used in disk 
20 recording system. 

FIG. 39 is a schematic diagram depicting the invention as used to effect 
automatic phase rotation equalization of a QAM signal. 

FIG. 40A is a signal constellation diagram for a QAM system with four 
amplitude-phase states by way of illustration. 
25 FIG. 40B is a diagram similar to FIG. 40A, showing a phase rotation of 

9 as a result of propagation of the signal to the receiver. 

FIG. 41 is a block diagram showing extension of the cumulant recovery 
system of the invention to cover a wide frequency band. 
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DESCRIPTION OF THE PREFERRED EMBODIMENTS 
1.0 Introduction: 

Because the present invention encompasses a number of different but 
related concepts and applications, and because the key signal processing concepts of the 
invention can be implemented in several different embodiments, this detailed 
description is divided into sections and subsections, each of which covers a different 
specific embodiment or practical application of the invention. The following is a table 
of contents of this description of the preferred embodiments: 
1.0 Introduction 

2.0 Overview of the Concept of the Invention 

2.1 Signal Separation Concept 

2.2 Signal Separation Concept in the Multipath Environment 

2.3 Direction Finding Concept 

2.5 Transmitter/Receiver Concept 

2.6 Concept of Separation of Signals in a "Waveguide" 

3.0 Preferred Embodiment Using EigenCumulant Recovery (eCURE) 
System 

3 . 1 Overview and System Hardware 

3.2 Preprocessing 

3.3 Operation of an Active Signal Extraction Port 

3.4 The Signal Recovery Controller 

3 . 5 The Orthogonalizer 

3 . 6 Operation at an Inactive Port 

4.0 Alternate Embodiment Using Covariance Inversion Cumulant Recovery 
(CiCURE) System 

5.0 Alternate Embodiment Using Pipelined Cumulant Recovery (pipeCURE) 
System 

5 . 1 Overview of the pipeCURE Signal Separator 



WO 98/24192 



PCT/US96/18867 



-23- 

5 . 2 Preprocessor Unit 

5 . 3 Cumulant Matrix Computer 

5.4 Multiple Port Signal Recovery Unit 

6.0 Steering Vector Tracking Method for Situations Having Relative Motion 

7.0 Alternate Embodiment Using Direct Computation 

8.0 Separation Capacity and Performance When Overloaded 

9.0 Performance of the Invention in the Presence of Multipath 

9. 1 Performance Against Coherent Multipath 

9.2 Performance Against Noncoherent Multipath 

9.3 Performance Against Mixtures of Coherent and Noncoherent 
Multipath 

10.0 Signal Recovery in the Presence of Strong Interfering Signals 
1 1 .0 Diversity Path Multiple Access (DPMA) Communication 

11.1 History and Prior Art of Multiple Access Communication 

11.2 A New Method of Multiple Access Communication 
12.0 Application to Two- Way Wireless Communication Systems 

12.1 Transmit Beamforming 
13.0 Application to Recovery of Multimode Signals 
14.0 Application to Separation of Signals Transmitted Over "Waveguide" 
15.0 Application to Radio Direction Finding 

16.0 Application to Extending the Dynamic Range of Receiving Systems 
17.0 Application to High Density Recording 
18.0 Application to Complex Phase Equalization 
19.0 Extension to Wideband Signal Separation 

19.1 Partitioning Wideband Measurements to Narrowbands 

19.2 Signal Separation in Narrowbands 

19.3 Combining Narrowbands 
20.0 Conclusion 



30 
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2.0 Overview of the Concept of the Invention: 

The present invention resides in a system and method for processing 
signals received by a sensor receiving system having an array of sensor elements. The 
system is capable of receiving and processing a signal from a single source, and for 
5 purposes of explanation the system will sometimes be described as receiving and 
processing just one signal. It will, however, shortly become clear that the system is 
capable of, and best suited for, receiving and processing signals from multiple sources, 
and that the multiple signals may utilize overlapping signal frequency bands as viewed 
at the receiver, i.e. they may be cochannel signals. As discussed above in the 
10 "background of the invention" section, detection and processing of cochannel signals 
presents difficulties that have not been adequately addressed by signal processing 
systems of the prior art. 

One central concept that makes the various aspects of overall invention 
possible is the ability to determine accurate estimates of generalized steering vectors of 
15 the source signals incident on a sensor array or, more generally, estimates of the linear 
combinations that represent the relative amplitudes of the source signals in each 
channel of a multichannel signal stream. The meaning of the term "generalized steering 
vector" will become better understood as this description proceeds. A definition for 
present purposes is that the generalized steering vector associated with a particular 
20 signal source represents the weighted sum of ordinary steering vectors corresponding 
to all multipath components of signals from that source. An ordinary steering vector is 
the value of the array manifold at a single angle corresponding to a source's DOA. 
Multipath components arise when a signal from a single source reaches a receiver over 
multiple propagation paths. 
25 The invention encompasses three distinct methods for determining 

estimates of the generalized steering vectors of source signals. FIG. 1 illustrates the 
taxonomy and relationships among the methods. Two of the methods for determining 
the estimated generalized steering vectors (EGSVs) involve iterative computations. 
The first of these, indicated by reference numeral 10, is called the "beamform - cross- 
30 cumulant" method. In this method, an initial EGSV is iteratively updated and 
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improved by a method that involves using the initial EGSV as a complex weight vector 
in a linear beamformer that operates on sensor signals (i.e., signal measured at a sensor 
array, to be discussed shortly with reference to other drawing figures). Cross- 
cumulants are computed, specifically between the output signal from the beamformer 
5 used in this method and each of the beamformer's input signals. 

The term "cumulant" is defined more completely in later sections of this 
specification, but for purposes of this general discussion it is sufficient to note that 
cumulants are fourth-order (or higher even-order) statistical moments of the received 
signals. The cross-cumulants are formed into a vector which, upon normalization, 
10 becomes the next EGSV. This iteration cycle is repeated until convergence is attained, 
based on a predefined convergence test or on a selected number of iteration cycles. 
Upon convergence, the EGSV will have converged to the generalized steering vector of 
one of the incident source signals. 

The second iterative method for obtaining EGSVs is referred to as the 
15 "C- matrix" method and is indicated at 12 in FIG. 1. In this method, a particular 
matrix of cross-cumulants among the sensor signals is calculated first, before the 
iterative process starts. There are no subsequent calculations of cumulants within the 
iterative cycle. Instead, an initial EGSV is used to calculate a structured quadratic 
form, which yields a quantity called "cumulant strength." The EGSV is adjusted to 
20 maximize the cumulant strength by means of an iterative optimization procedure. Upon 
convergence, the EGSV will have converged to the generalized steering vector of one 
of the incident source signals. 

The third method of finding the EGSVs is non-iterative. It is referred to 
as the "direct computation" or "analytic" method and is indicated at 14 in FIG. 1. This 
25 method can only recoverup to two incident signals, but is unrestricted as to the number 
of sensor array elements or processing channels. The method first computes the same 
matrix of cross-cumulants among the sensor signals as is used in the second iterative 
method. However, a fourth degree polynomial equation is solved instead of optimizing 
a structured quadratic form. The solutions to the fourth degree polynomial yield the 
30 final EGSVs directly without iteration. 
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In addition to the three methods for generating the EGSVs of the source 
signals, the present invention has three alternative basic algorithmic structures on 
which the preferred embodiments of the invention are based. FIG. 1 shows 
diagrammatically that the EGSVs generated by either of the three methods (10, 12 or 
5 14) are coupled over line 16 to a selected one of three algorithmic structures 18, 
referred to as CiCURE, eCURE, and pipeCURE. As will be further explained below, 
the acronym CURE stands for cumulant recovery. The terms CiCURE, eCURE and 
pipeCURE refer to specific embodiments of the invention known as covariance 
inversion CURE, eigenCURE and pipe lined CURE, respectively. Each structure 
10 encompassed by the block 18 in FIG. 1 can employ any of the three methods (10, 12 or 
14) described above for determining the source signal EGSVs. 

By way of example, a subsequent section of this specification (Section 
3.0) describes a preferred embodiment consisting of the eCURE algorithmic structure 
and the beamform - cross-cumulant method. Another section (Section 5.0) details a 
15 preferred embodiment consisting of the pipeCURE structure and the C-matrix method. 
However, all other combinations are possible and may be preferable depending on the 
specific engineering application. 

The algorithmic structures (18) are described below in subsequent 
descriptive sections as processing input samples in a "batch processing" mode, meaning 
20 that sampled data from the sensor signals are grouped into blocks of samples, which 
are then processed one block at a time. The block size is arbitrary and is not intended 
to limit the scope of the present invention. For example, the block size can be as small 
as one, in which case, the batch mode reduces trivially to "sample-by-sample" 
processing. 

25 In some situations, the EGSVs of the source signals vary with time, due, 

for example, to changing geometric relationships among the locations of the sources, 
the receiving sensor array, or multipath reflectors. For such situations, two methods 
are presented for determining the initial EGSVs for each block of samples. These 
methods incorporate a technique known as oc-p tracking into the block initialization 

30 process and thereby make the acquisition, capture, separation, and recovery of source 
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signals more stable when any of the sources or the receive sensor array is moving. 
Two block initialization methods are presented for this purpose and are called cc- 
PCURE and uGURE. As indicated by block 19 in FIG. 1, these two methods are 
applicable to any of the basic algorithmic structures 18. 
5 FIG. 2A shows the system of the present invention in general form, 

employing the first iterative method referred to above as the beamform - cross- 
cumulant method. The system includes four principal components: a sensor receiving 
system 20, an estimated generalized steering vector (EGSV) computation module 22, a 
supplemental computation module 24 and a linear combiner 26. 
10 The sensor receiving system 20 includes components not shown in 

FIG. 2A, but which will be discussed in more detail below, including an array of 
sensors to convert incident signals into electrical form, and some form of signal 
conditioning circuitry. In each of the embodiments and applications of the invention, 
incident signals 27 are sensed by the sensor receiving system 20 and, after appropriate 
15 processing, the supplemental processing module 24 generates desired output signals or 
parameters as needed for a specific application of the invention. For example, in a 
signal separation application, the output signals will be the reconstructed cochannel 
signals received from separate signal sources. An important aspect and advantage of 
the invention is that the received signals may be of any modulation or type. 
20 A key component of the signal processing system of the invention is the 

estimated generalized steering vector (EGSV) computation module 22, which receives 
the conditioned received signals over line 28 from the sensor receiving system 20, and 
computes an EGSV from the conditioned signals. The EGSV, in accordance with the 
invention, results in optimization of a utility function that depends on fourth or higher 
25 even-order statistical cumulants derived from the received signals. At this point in the 
description, cumulants have not yet been defined, but they are discussed in Section 4.0. 
For the present, it is sufficient to note that cumulants are fourth-order (or higher even- 
order) statistical moments of the received signals. 

The EGSV computation module 22 functions in an iterative manner in 
30 cooperation with the linear combiner 26. The linear combiner 26 begins a first iteration 
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with an initial EGSV, indicated at 30, which may be an estimate or simply a random 
initial vector quantity. The linear combiner 26 then combines the received signals on 
line 28 with the initial EGSV and generates a single-channel combined signal on line 32 
to the EGSV computation module 22. The latter performs its cumulant computation and 

5 generates a revised EGSV, which is fed back to the linear combiner 26 over line 34. 
The iterative process continues until the EGSV has converged to an appropriately 
accurate solution, which is output to the supplemental computation module 24 over line 
36. The output on line 36 is also referred to as an estimated generalized steering 
vector, which closely approximates the actual generalized steering vector and 

10 represents the weighted sum of ordinary steering vectors corresponding to all multipath 
components of signals from a source. Where no multipath components are present, the 
generalized steering vector reduces to an ordinary steering vector for the source. 
However, the term "generalized" steering vector is used frequently in this 
specification, to convey the meaning that the steering vector generated automatically 

15 and dynamically takes into account the possibility of receiving a signal over multiple 
paths. 

The function of the supplemental computation module 24 depends on the 
specific application of the invention. This module makes use of the conditioned 
received signals on line 28 and the generalized steering vector on line 36, and 
20 generates the desired output signal or parameters on output line 38. 

It should be understood that the components shown in FIG. 2A, and in 
particular the EGSV computation module 22 and the linear combiner 26, function to 
generate a single estimated generalized steering vector on line 36, corresponding to a 
single signal source from which signals are received at the sensor receiving system 20. 
25 In a number of applications, as will be further described, multiple linear combiners 26 
and multiple EGSV computation modules 22 will be needed to separate signals from 
multiple sources. Similarly, in most applications the supplemental computation module 
24 must also be replicated, at least in part, to generate multiple desired output signals. 

Another aspect of FIG. 2A to keep in mind is that it is an imperfect 
30 attempt to depict a number of the invention's many possible forms in a single 
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conceptual diagram. The concept of the generalized steering vector is central to all 
forms of the invention. The estimated generalized steering vector (EGSV) provides a 
means for tracking sources through time free of discontinuity. The estimated 
generalized steering vector computational module, 22 in FIG. 2A, may be partially 

5 merged with the supplemental computation module 24 or the order of computation 
modified to accommodate physical implementation. This is true in the case of a specific 
implementation of a signal recovery system, described subsequently, in which 
recovered signals are generated as outputs of the supplemental computation module 24. 

An important aspect of the invention is that the EGSV computation 

10 module 22, or multiple modules in some embodiments, compute estimated generalized 
steering vectors extremely rapidly, either by direct computation or by an iterative 
process that converges superexponentially. Moreover, each EGSV represents the 
weighted sum of steering vectors associated with multipath components derived from a 
single signal source. As will be described in the next descriptive subsection, multiple 

15 EGSVs can be conveniently processed to reconstruct and separate signals from multiple 
signal sources. 

As the description of the various embodiments proceeds, it will become 
apparent that certain components of the invention are common to many applications. In 
terms of the components shown in FIG. 2A, the common components include the 
20 EGSV computation module 22, the linear combiner 26 and signal conditioning portions 
of the sensor receiving system 20. Accordingly, in many instances it would be 
advantageous to fabricate these components as a monolithic semiconductor device or 
chip, to be mounted in close association with other components in the supplemental 
computation module 24, which vary by application. Alternatively, a set of 
25 semiconductor chips could include various embodiments of the supplemental 
computation module 24, such as for signal separation, direction finding and so forth. 

FIG. 2B illustrates the form of the invention that uses the second 
iterative method (12, FIG. 1), called the C-matrix method, for generating EGSVs. It 
will be observed that the figure is similar to FIG. 2A, except that there is no linear 
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combiner. Instead there is a cross-cumulant matrix computation module 40 and a 
structured quadratic form computation module 42. 

The cross-cumulant computation module 40 receives conditioned sensor 
signals over line 28 from the sensor receiving system 20, computes the cross-cumulants 

5 of all combinations of the sensor signals and stores the results in a matrix having a 
particular mathematical structure. This matrix of cross-cumulants, denoted C, has 
dimensions P^P 2 , where P is the number of signal sources, and is stored for 
subsequent computations. This C matrix is computed before any iterative computations 
are performed, and it will be noted that the EGSVs fed back from the EGSV 

10 computation module 22 over line 34 are coupled to the structured quadratic form 
computation module 42 and not to the cross-cumulant matrix computation module 40. 

The structured quadratic form computation module 42 is used in an 
iterative computational loop that, starting with an initial estimated generalized steering 
vector (EGSV) on line 30, produces a series of successively improved values for the 

15 EGSV, until a termination test is satisfied. In each cycle of the iterative loop the 
module 42 receives an input EGSV and outputs a cumulant strength function (on line 
32), which is obtained by computing a structured quadratic form involving the C 
matrix and the input EGSV. The mathematical details of the computation are described 
in a later section. The cumulant strength function, so obtained, is output to the EGSV 

20 computation module 22 to update the EGSV. As in FIG. 2A, the nature of the 
supplemental computation module 24 in FIG. 2B depends on the particular application 
of the invention. 

The EGSV computation module 22 together with the structured 
quadratic form computation module 42 are part of an iterative computational loop that 
25 produces a series of successively improved values for an EGSV of a source signal, 
starting from an initial value. The EGSV computation module 22 receives as input a 
cumulant strength value for the current value of an EGSV. Based upon this cumulant 
strength, the module 22 determines a new value for the EGSV that will cause the value 
of the cumulant strength value to increase in absolute value. This new EGSV is output 
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to the structured quadratic form computation module, where it replaces the old EGSV, 
and the computation cycle is repeated until a termination test is satisfied. 

FIG. 2C depicts the direct computation method of the invention in 
conceptual form using the same basic structure as FIGS. 2A and 2B. The EGSV 

5 computation module in this figure is referred to by numeral 22', since it performs its 
function differently from the module 22 in FIGS. 2 A and 2B. The EGSV computation 
module 22' receives as input the C matrix computed by the cross-cumulant matrix 
computation module 40. The EGSV computation module 22' computes the solutions to 
a fourth degree polynomial equation, from which the EGSVs of one or two sources are 

10 directly determined. The mathematical details of the particular polynomial equation 
are described in a Section 7.0. The values of the EGSVs, so determined, are output to 
the supplemental computation module 24. 

It will be understood that FIGS. 2A, 2B and 2C illustrate the processing 
required to recover a single source signal from among a plurality of possible source 

15 signals, for purposes of explanation. We will now turn to the case of recovery of 
multiple signals. 

2.1 Signal Separation Concept: 

The present invention has a number of applications in the 
20 communications field and, more specifically, in the separation of cochannel signals. 
FIG. 3A illustrates the concept of signal separation using the first iterative method (10, 
FIG. 1) and differs from FIG. 2 A in that there are multiple linear combiners 26.1 
through 26.P and multiple estimated generalized steering vector (EGSV) computation 
modules 22.1 through 22.P. The supplemental computation module 24 has been 

25 replaced by a supplemental computation module 24 A for signal recovery, the details of 
which will be explained with reference to FIG. 4A. The sensor receiving system 20 
outputs the received signals in conditioned form on line 28, which is connected to each 
of the linear combiners 26 and EGSV computation modules 22. Signal conditioning in 
the sensor receiving system, 20, which is described subsequently, may be used to 

30 transform the received signals to P sets of signals, where P is the number of signal 
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sources being received, and to be separated. As in FIG. 2A, the EGSV computation 
modules 22 and the linear combiners 26 cooperate to produce converged values of 
estimated generalized steering vectors on output lines 28.1 through 28. P. The 
supplemental computation module 24A uses these generalized steering vectors and the 
5 received signals on lines 28 to generate P separate recovered signals on lines 38. How 
this latter step is accomplished is best understood from FIG. 4A, which will be 
discussed after consideration of FIGS. 3B and 3C. 

FIG. 3B depicts a cochannel signal separation and recovery system 
similar to that of FIG. 3A, but using the second iterative method (12, FIG. 1). As in 
10 FIG. 2B, there is a single cross-cumulant matrix computation module 40 but, unlike the 
FIG. 2B system, there are multiple (P) structured quadratic form computation modules 
42.1, 42.2 ... 42. P, each of which receives cross-cumulants from the matrix 
computation module 40 and conditioned input signals from line 28. Cumulant strength 
values generated by the structured quadratic form computation modules 42 are supplied 
15 to respective EGSV computation modules 22.1, 22.2 ... 22.P, which output 
recomputed EGSVs for feedback over lines 34.1, 34.2 ... 34.P, respectively, to the 
structured quadratic form computation modules 42.1, 42.2 ... 42. P, and converged 
values of the EGSVs on lines 36.1, 36.2 ... 36.P. 

FIG. 3C depicts a signal separation and recovery system similar to those 
20 of FIGS. 3 A and 3B, but using direct computation instead of an iterative method. This 
figure is also closely similar to FIG.2C, except that the ESGV computation module 22' 
generates two EGSVs on output lines 36.1 and 36.2, and supplemental processing is 
performed in the supplemental computation module for signal recovery, which 
generates two recovered signals for output on lines 38.1 and 38.2. 
25 As shown in FIG. 4A, the supplemental computation recovery module 

for signal recovery 24A includes a recovery beamformer weight vector computation 
module 44 and multiple recovery beamformers 46.1 through 46. P. Computation of the 
weight vectors in module 44 is made in accordance with a selected known technique 
used in signal processing. The beamforming weight vectors for signal recovery are 
30 computed directly from the generalized steering vectors. This is done by one of two 
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methods: (1) by projecting each generalized steering vector into the orthogonal 
complement of the subspace defined by the span of the vectors of the other sources by 
matrix transformation using the Moore-Penrose pseudo-inverse matrix; or (2) by using 
the Capon beamformer, also called the Minimum Variance Distortionless Response 

5 (MVDR) beamformer in the acoustics literature. The module 44 generates, from the P 
input estimated generalized steering vectors (EGSVs), a set of P weight vectors w, 
through w P , on lines 48.1 through 48. P. Implicit in the function performed by the 
module 44 is the orthogonalization of the output signals, such that the weight vectors 
are mutually orthogonal, i.e. each is representative of a separate signal. Alternatively, 

10 the module 44 may be implemented in the manner described in Section 3.0. 

The weight vectors W[ through w P are applied to the received, 
conditioned signals on line 28, in the recovery beamformers 46.1 through 46. P. This is 
basically a process of linear combination, wherein each signal component is multiplied 
by a corresponding component of the weight vector and the results are added together 

15 to produce one of the recovered signals. 

As will be seen from the more detailed description of the preferred 
embodiments, the functions of the linear combiners 26 (in the case of FIG. 3A), the 
EGSV computation modules 22, the recovery beamformer weight vector computation 
module 44 and the recovery beamformers 46 may be combined in various ways. 

20 Moreover, all of these functions, together with signal conditioning performed in the 
sensor receiving system 20, may be conveniently implemented in one or more 
integrated circuits. 

2.2 Signal Separation Concept in the Multipath Environment: 

25 As will be later described in more detail, signal separation in accordance 

with this invention has important advantages in the context of multipath signal 
processing. Communication signals, particularly in an urban environment, often reach 
a receiver antenna over multiple paths, after reflection from geographical features, 
buildings and other structures. The multiple signals arrive at the antenna with different 

30 signal strengths and subject to relative time delays and other forms of distortion. 
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Because they arrive from different directions, such signals may be separated in a 
conventional cochannel signal separation system. However, the cochannel signal 
processing system of the present invention will automatically combine the multipath 
components if they are still coherent with each other. Coherency, in this context, is a 
5 relative term that simply indicates the degree to which the signals are identical. 
Multiple signals are classified as coherent if they are relatively similar to each other, as 
measured by a cross-correlation function over a finite time interval. Multipath 
components are noncoherent, and therefore not combinable, when they suffer large 
relative time delays or when a signal transmitter or receiver is in motion, causing a 
10 Doppler shift in the transmitted signal that affects one path more than another. 

The key to successful processing of multipath components is that each 
generalized steering vector referred to with reference to FIGS. 1, 2A-2C and 3A-3C 
corresponds to the sum of all of the mutually coherent multipath components of a 
signal source incident on the sensor receiving system 20. The generalized steering 
15 vectors from all signal sources are then converted to a set of beamforming weight 
vectors (in recovery beamformer weight vector computation module 44), without the 
need for knowledge of array geometry or array manifold calibration data (which relates 
array steering vectors with angles of arrival for a particular array). For many of its 
applications, the invention is, therefore, completely "blind" to the array manifold 
20 calibration data and the physical parameters of the array. 

2.3 Direction Finding Concept: 

The invention as described with reference to FIGS. 2A-2C, 3A-3C and 
4A provides for cochannel signal separation, even in a multipath environment, without 

25 use of specific sensor array manifold information. The array parameters, and 
specifically array calibration data that relate array steering vectors with directions of 
signal arrival, are needed if one needs to know the angular directions from which 
signals are being received. FIG. 4B illustrates this concept for a single signal source 
referred to as source k. Although the concept depicted in FIG. 4B is conventional, the 

30 manner in which the present invention generates the input steering vectors is novel. A 
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generalized steering vector, referred to as a** is received from one of the EGSV 
computation modules 22. k (FIG. 3A) on line 36. k and is processed in a direction of 
arrival (DO A) search module 24B, which is a specific form of the supplemental 
computation module 14 (FIGS. 2A-2C). The DO A search module 14B uses stored 

5 array calibration data 50, which associates each possible direction of arrival with a 
steering vector. These calibration data are typically stored in a memory device as a 
lookup table. In the DO A search module 24B, a reverse table lookup is performed to 
obtain the two closest directions of arrival from the input steering vector, as indicated 
in block 52. Then a more precise angle of arrival is obtained by performing an 

10 interpolation between the two angle values retrieved from the calibration data 50, as 
indicated in block 54. The direction of arrival (DO A) parameter for the fc* signal 
source is output from computation module 24B on line 38. k. 

2.4 Transmitter/Receiver Concept: 

15 As will be discussed further in section 12.0, an important application of 

the invention is to two-way communication systems. In many communication systems, 
the allocation of transmission frequencies within a geographical area, such as in a 
predefined cell in a cellular telephone system, is often a limiting factor that determines 
the maximum number of active users that the system can handle. In accordance with 
20 this aspect of the present invention, information derived from signals received and 
separated in a receive mode of operation are used to generate signals to a transmit 
antenna array, in such a way that separate information signals can be transmitted to 
respective remote stations using the same frequency. 

As already discussed, the present invention makes use of an array of 
25 sensors or antennas to separate received signals of the same frequency (cochannel 
signals). In a two-way communication system of the type having multiple mobile units, 
it would be impractical, in general, to require the use of an antenna array at each 
remote or mobile transmitter/receiver. These remote units may be installed in vehicles 
or be hand-held devices for which the use of an antenna array is either inconvenient or 
30 simply impossible. However, in most communication systems, the communication path 
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between remote units is completed through one or more base stations operating as a 
receiver and transmitter. Since the base stations are generally larger and more powerful 
than the mobile units and are fixed in location, they may be conveniently structured to 
include antenna arrays for both receiving and transmitting. As discussed above, a 
5 receive array connected to the system of the invention provides for separation of 
received cochannel signals. Moreover, an important by-product of the signal separation 
process is a set of generalized steering vectors, each associated with a separate signal 
source. 

As shown in FIG. 5 for a single remote transmitter/receiver station, 
10 received signals are recovered on line 38, in the manner discussed with reference to 
FIG. 2A. In a two-way communication system, a transmitter 56 uses the generalized 
steering vector corresponding to the received signal source, obtained from the EGSV 
computation module 22, in order to generate a weight vector for application to a 
transmit antenna array (not shown). The transmitter 56 also receives, on line 58, an 
15 information signal to be transmitted. Typically, this will be in the form of a digitized 
voice signal, although it may be a data signal of some other type. The transmitter 56 
generates the transmit weight vector in accordance with a technique to be described 
below in Section 12.0, modifies the information signal in accordance with the weight 
vector, modulates a carrier signal with the weighted information signal components, 
20 and sends a set of signals to the transmit array, as indicated by lines 60. The carrier 
frequency, although the same for each of the transmitted cochannel signals, is usually 
selected to have a frequency different from the receive signal frequency. As will also 
be further discussed below, in the more general case of multiple received signals and 
multiple transmitted signals, the transmitter 56 generates multiple weight vectors, 
25 which are applied to the respective information signals to be transmitted, then linearly 
combined, antenna element by antenna element, and finally modulated to produce a set 
of composite antenna element signals for coupling to the transmit antenna array. 

It will be appreciated that this aspect of the invention provides a simple 
but effective technique for use in a communication system base station, for receiving 
30 cochannel signals from, and transmitting cochannel signals to, multiple remote stations 
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in close proximity to a base station and to each other. Limited only by the number of 
elements in the receive and transmit arrays, the technique allows for re-use of the same 
frequencies in the multiple remote stations, with a resultant increase in system capacity 
or user density, e.g. the number of users per frequency per unit area (per cell or sector 
5 thereof). 

2.5 Concept of Separation of Signals in a "Waveguide": 

Up to this point in the description, it has been tacitly assumed that the 
"incident signals" 27 shown in FIGS. 2A-2C and 3A-3C are signals transmitted 

10 through space, the atmosphere, the ocean or some other relatively unbounded medium. 
As will be described in more detail in descriptions of various embodiments of the 
invention, cochannel signals transmitted on a waveguide of some type may also be 
received and processed in accordance with the principles of the invention. The term 
waveguide is used in quotation marks in the heading of this descriptive subsection 

15 because the term is not intended to be limited to a waveguide operating at microwave 
frequencies, or to an optical waveguide in the form of an optical fiber or planar optical 
waveguide. Instead, the word waveguide as used in this specification is intended to 
cover any of various types of bounded transmission media, including microwave 
waveguides, optical waveguides, coaxial cables, or even twisted pairs of conductors 

20 operating at relatively low frequencies. 

A common attribute of these "waveguides" is that multiple signals may 
be transmitted along them using the same frequency but different modes of 
transmission, such as different polarization modes for microwave or optical 
waveguides, or, in the case of twisted-pair conductors, different signals being applied 

25 to different wire-to-ground combinations. For various reasons, however, the 
propagation modes may become scrambled in the propagation medium and may 
become difficult or impossible to separate in a receiver. As shown in FIG. 6, a system 
in accordance with the invention can be usefully employed to separate such signals. 
Except for the sensor receiving system 20, the system of FIG. 6 is identical with the 
30 FIG. 3 A system for separating received signals. The "incident signals" 27 are received 
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from a signal "waveguide" 62, as defined in the preceding paragraph, and are sensed 
by "waveguide" sensors 52. In the case of a microwave or optical waveguide, the 
sensors 64 take the form of electromagnetic probes or optical sensors appropriately 
inserted into the waveguides. For twisted-pair conductors, the sensors may include 
5 appropriate circuitry connected to the conductors and ground. Signals from the sensors 
64 are subject to received signal conditioning, as indicated in block 66, and are then 
input to the signal separation system of the invention in the same way as signals from 
multiple elements of an antenna array. The system recovers the original signals as 
indicated on lines 38. 

10 Another application of the invention is similar in some respects to the 

recovery of signals from a bounded waveguide. In magnetic recording systems using a 
high density recording medium in which recording tracks are positioned very close to 
each other, there is always the potential for crosstalk between the signals on adjacent 
parallel tracks. Maintaining an acceptably low level of crosstalk imposes a limitation on 

15 the proximity of the tracks and the overall recording density. In this embodiment of the 
invention, a higher level of crosstalk can be tolerated because signals retrieved from 
adjacent tracks can be separated using the signal recovery system of the invention. In 
this case, the "waveguide" sensors 64 are adjacent playback sensors in a magnetic 
recording apparatus. There is no "waveguide" as such; nor are the signals transmitted 

20 through an unbounded medium. Instead they are sensed electromagnetically from a 
recording medium on a moving magnetic tape or disk. 

2.6 Preview of Iterative Embodiments to be Described: 

As discussed in more general terms above, there are two alternative 
25 iterative methods that may be used in accordance with the invention in the context of 
separation and recovery of cochannel signals. Before proceeding with the detailed 
descriptions of those methods in terms of specific embodiments, it may be helpful to 
provide a an overview of the iterative methods at a different level of abstraction from 
that of the preceding figures. FIG. 7 provides the basis for this overview. Some of the 
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technical terms used in FIG. 7 are introduced for the first time in this specification and 
may not be completely clear until the complete description is studied. 

As shown in FIG. 7, the signal separation and recovery process involves 
a number of manipulations of the estimated generalized steering vectors (EGSVs) 
5 pertaining to the multiple signal sources. In block 70 EGSV initialization is performed. 
This is simply the selection of initial EGSV values (on line 30 in FIGS. 2A and 2B) 
from which to begin processing. It will be recalled that processing is performed in a 
batch mode in which sequential blocks of data are processed. The initial EGSVs may 
be estimates carried forward from an already processed previous block of data, or they 
10 may be generated from scratch, using either random quantities or a cumulant eigen- 
decomposition algorithm. 

Another function performed in block 70 is to "project" the initial 
EGSVs into a P-dimensional signal space, where P is the number of signal sources. 
The antenna array provides sets of input data signals that are M-dimensional, where M 
15 is the number of elements in the array. Throughout the computations performed in 
accordance with the invention, there is often a design choice to be made because the 
mathematical manipulations may be performed on these M-dimensional vector 
quantities, or on corresponding P-dimensional quantities, where P is the number of 
signal sources. Ultimately, the recovered signals are output as P one-dimensional 
20 signals, since there is one recovered signal per source, but signal recovery requires 
beamforming in the sensor space. The transformation from M-dimensional sensor space 
to P-dimensional signal space is called "projection," and the reverse transformation, 
from P-dimensional signal space to M-dimensional sensor space, is called 
"backprojection. " 

25 Block 72 in FIG. 7 describes EGSV prioritization. This aspect of the 

invention has not yet been discussed but, simply stated, prioritization is needed to 
provide a rational basis for choosing which of multiple signals should be recovered 
first. The sensor array, having M elements, inherently limits the number of cochannel 
signals that may be recovered to M. If more than M signal sources are actively 

30 transmitting, the first M signals are selected on the basis of their non-Gaussianity, as 
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determined by either of two methods: using the C-matrix or beamforming and 
computing cross-cumulants. The resulting priority list of sources is passed to a signal 
separation iteration block 74, which uses one of the two iterative methods to obtain 
convergence for each EGSV in turn, starting with the highest priority source. The steps 
5 of the iterative procedure include updating the EGSV using either the C-matrix or the 
beamforming and cross-cumulant computations, then using a conventional technique, 
such as the Gram-Schmidt procedure, to ensure that each EGSV is orthogonal to 
already-processed higher-priority EGSVs. These steps are repeated until convergence 
is achieved for each signal source. 
10 Block 76 of FIG. 7 describes another practical issue in signal recovery 

systems that use batch processing. Each "port" from which a recovered signal is output 
in processing a block of data must be correctly associated with a recovered signal from 
the previous data block. This association is performed by comparing the EGSVs. The 
ports cannot be associated merely on their positions in the priority list because signal 
15 sources may come and go from list as time passes. 

Another batch processing issue is addressed in block 78 of FIG. 7. The 
phase angle of an EGSV generated in processing one block of data may not exactly 
match the phase angle as determined in the next block. This processing step applies an 
EGSV phase adjustment to eliminate any discontinuity from block to block. 
20 Next, in block 80 of FIG. 6, the EGSVs are "backprojected" from the 

P-dimensional signal subspace to the M-dimensional sensor space and then, in block 
82, the backprojected EGSVs are used to beamform and recover the output port 
signals. 

This overview provides an introduction into the various embodiments 
25 and forms that the invention may take. The foregoing and other aspects of the invention 
will now be discussed in more detail. 

3.0 Preferred Embodiment Using eCURE: 

As discussed more generally above, the present invention pertains to a 
30 system and method for processing and recovering cochannel signals received at a 
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sensor array. In this descriptive section, a practical embodiment of the cumulant 
recovery (CURE) system is disclosed. Because this embodiment uses eigenvectors and 
eigenvalues in part of its computation, it is referred to as the eigenCURE system, or 
simply the eCURE system. The embodiment disclosed uses the first iterative method 
5 (the beamform and cross-cumulant method, first introduced at 10 in FIG. 1). It will be 
understood, however, that the eCURE system may be modified to use the C-matrix 
iterative method (12, FIG. 1). 

3.1 Overview And System Hardware: 

10 FIG. 8A shows the basic components of the eCURE system, including a 

sensor array, indicated by reference numeral 110, which receives signals from various 
directions, as indicated at 112, a bank of receivers 114, and a sampler and analog-to- 
digital converter bank 116. The separate signals from the elements of the sensor array 
110 are coupled directly to the receiver bank 114, which performs conventional 

15 filtering and frequency downconversion functions. The sensor signals are then 
sampled at a high rate and converted to digital form in the sampler and analog-to- 
digital converter bank 16. At this point, the signals have been filtered, downconverted 
and digitized and processing is about to begin. It can be appreciated that, because each 
sensor in the array 110 provides a stream of digitized signals, processing may be 

20 conveniently performed in batches or blocks of data. From time to time, reference will 
be made in this description to current and previous data blocks. The block size is 
critical only in the sense that the size selected affects processing speed and accuracy of 
estimation. 

The first major processing step is preprocessing the sensor data, which 
25 is performed in a preprocessing computer 120. As will be discussed in more detail 
with reference to FIG. 10, the preprocessing computer 120 performs four important 
functions: 

• It "whitens" the directional components of the signals using a technique 
known as eigendecomposition, which will be discussed further below. 
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• It estimates the number of signal sources being received. P is the number of 
sources and P e is the estimated number of sources. 

• It reduces the dimensionality of the sensor data from M, the number of 
sensors, to P e , the estimated number signal sources. 

5 • It scales the numerical values of the signals to normalize the powers of the 

sources, permitting weak signals to be separated in addition to stronger 
ones. 

The other major components of the cochannel signal recovery system are 
a signal recovery controller 122, multiple signal extraction ports 124.1 through 124. L, 
10 an orthogonalizer 126, and multiple demodulators 128. Preprocessed sensor signals 
are transmitted over lines 130 in parallel to each signal extraction ports 124.1. Each 
port in this embodiment of the invention is implemented as a separate computer 
processor. Using the iterative technique described above with reference to FIGS. 2 A 
and 3 A, each of the signal extraction ports 124 generates output signals derived from a 
15 separate source. These signals are output on lines 132 to the demodulators 128, which 
produce usable output signals on lines 134. If the information contained in the signals 
is audio information, the outputs on lines 134 may be connected to separate 
loudspeakers or other audio processing equipment (not shown). The function of the 
orthogonalizer 126 is to ensure that each of the ports 124 is associate with a separate 
20 signal source. The signal recovery controller 122 performs various control functions 
in conjunction with the signal extraction ports 124 and the orthogonalizer 126. The 
controller 122 receives the source count estimate P e from the preprocessing computer 
120 over line 136 and also receives eigenstructure parameters from the preprocessing 
computer over line 138. The latter are also transmitted to the signal extraction ports 
25 124, and the source count estimate is transmitted to the orthogonalizer 126. The 
controller 122 also sends a priority list to the orthogonalizer 126 over line 140. 
Finally, the controller 122 sends adaptation flags to the signal extraction ports 124 over 
lines 142 and receives capture strength values from the signal extraction ports over 
lines 144. The specific functions of these signals will become apparent as the 
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description proceeds. Basically, one function of the controller 122 is to keep track of 
signal sources as they appear and disappear and to make sure that the signal extraction 
ports 24 and the orthogonalizer 126 handle appearing and disappearing signal sources 
in an appropriate manner. 
5 In the general terms used in FIG. 3A, the sensor receiving system 20 

includes the sensor array 110, the receiving bank 114, the sampler and analog-to-digital 
converter 116 and the preprocessing computer 120. The functions performed by the 
linear combiners 26, the EGSV computation modules 22 and the supplemental 
computation module for signal recovery 24A, are performed in the signal recovery 
10 controller 122, the signal extraction ports 124 and the orthogonalizer 126. Because this 
practical embodiment must maintain association of signal sources to physical output 
ports, and must be able to adapt dynamically to the appearance and disappearance of 
signal sources, the architecture of the system is necessarily different from the 
conceptual architecture of FIGS. 2A, 3A and 4A. The fundamental functions 
15 performed in the system of FIG. 8A are, however, the same as those described with 
reference to the earlier figures. 

FIG. 8B is a hardware block diagram of one implementation of the 
eCURE system of the present invention, as used to separate multiple signals containing 
audio information. Identical reference numbers have been used in this figure to refer 
20 to components that appear in both FIG. 8A and FIG. 8B. The preprocessor computer 
120 is implemented as a separate circuit card. It is of little significance whether the 
preprocessor computer is implemented on a single circuit card or in a stand-alone 
computer. The functions performed in both cases would be identical. Similarly, the 
controller 122 and orthogonalizer 126 are implemented in one computer on a single 
25 circuit card, as indicated in FIG. 8B. The signal extraction ports 124, one of which is 
shown, are implemented on separate computers on circuit cards and the demodulators 
128 are also implemented on a separate computer. All of the computers mentioned 
above may be of any appropriate type, but in a presently preferred demonstration 
embodiment, they are Intel model i860 processors. The computers are connected to a 
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high-speed crossbar switching network 150, such as Part No. ILK-4, from Mercury 
Computer Systems, Lowell, MA, 01854. 

The sensors 110 may be of any appropriate type, such as Part No. 10- 
183-244, from TRW Inc., Sunnyvale, CA, 94088. The receivers 114 in this 
5 embodiment include a VME synthesizer module (Part No. 1600M SYN-5, from 
APCOM Inc., Gaithersburg, MD, 20878), a local oscillator module (Part No. 1600M 
LOD-1, also from APCOM Inc.) and a VME RF converter module (Part No. 1600M 
RFC-5, also from APCOM Inc.). The digitizer bank 116 may include an Access256 
motherboard (Part No. MOB256-4) and analog input and digital output cards from 
10 Celerity Systems, Inc., San Jose, CA, 95117. 

The receiver bank 114 tunes each sensor to the desired frequency and 
downconverts any signals received. One receiver is allocated to each sensor. The 
receivers 114 enable the system to isolate a single frequency of interest and to translate 
it to a frequency where it can be more conveniently digitized and processed. No 
15 demodulation is performed at this point. For example, one embodiment of the 
invention has receivers that downconvert the received signals to a center frequency of 
225 kHz and a bandwidth of 100 kHz (specifically the 3 dB bandwidth). 

The digitizer bank 116 converts the received signals to digital samples. 
Only real samples, not complex samples, are generated at this stage. In the illustrative 
20 system, the digitizer bank 116 consists of a digitizer motherboard and an input 
daughtercard that samples up to eight channels simultaneously at a rate of up to 10 
megasamples per second. The samples are exported for further processing through an 
input card 151. The data processing system performs digital filtering of the input data, 
with the digital filtering card 152, and converts the real samples to complex values 
25 needed for processing, using a real-to-complex conversion card 153. 

All of the processor cards mentioned above are connected to the high- 
speed crossbar switching network 150. A system manager 154 in the form of a Model 
68040 CPU (Part No. CPU-40B/ 16-02, from Force Computers Inc., San Jose, CA, 
95124) controls this demonstration system, with operator interface being provided by a 
30 workstation 56, such as a Powerlite notebook workstation (Part No. 1024-520-32, from 
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RDI Computer Corporation, San Diego, CA, 92008). In this hardware architecture, 
the demodulated signal outputs are connected to loudspeakers 157 and a hard disk drive 
158 is provided for storage of received messages. The system manager tunes the 
receivers 116, instructs the digitizer to record samples, configures and initiates 
5 operation of the data processing system, and controls a peripheral interface board (Part 
No. MVME 162-63, from Motorola Computer Group, Tempe, AZ, 85282), through 
which communication is had with the loudspeakers and the hard disk. It must be 
understood that, because this is a demonstration system, many of these components 
would not be needed in some implementations of the invention. As noted earlier, many 
10 of the components could be conveniently implemented in the form of a single integrate- 
circuit chip, or multiple chips. 

FIG. 9, which is broken into two figures designated FIGS. 9 A and 9B, 
is a block diagram similar to FIG. 8A but showing in each block more detail of the 
functions performed by each component of the system. The functions will be described 
15 with reference to the more detailed diagrams that follow. Another feature shown in 
FIG. 9 but not in FIG. 8A is the output of generalized steering vectors on lines 170. 
The generalized steering vectors, as discussed earlier in this specification, are an 
important product of the signal recovery process, along with the recovered signal 
outputs. The generalized steering vectors are shown as being used in a DF search 
20 processor 172, which generates signal source bearings or directions of arrival (DOA), 
output on lines 174, consistent with the description with reference to FIG. 4B. 

3.2 Preprocessing: 

The functions performed by the preprocessing computer 120 are shown 
25 in detail in FIG. 10. The preprocessor performs a block-by-block analysis of 
"snapshots" of data from the sensor array, which has M elements. The preprocessor 
determines the eigenvectors, the number of signal sources P, and the signal subspace of 
the received array measurement data. The preprocessor also filters the received array 
data, transforming it from M-dimensional sensor space to P-dimensional signal 
30 subspace. This transformation also renders the steering vectors of the transformed 
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sources orthogonal to each other, which greatly accelerates convergence on recovered 
signal solutions later in the processing, and the transformed source powers are made 
equal. 

A received signal that satisfies the narrow-band assumption (to be 
5 defined below) can be described by the following equation: 
r(0 = As(r) +n(f), 

where r(0 denotes the array measurements collected by M sensors, n(t) is the 
measurement noise, A is the steering matrix that models the responses of the sensors to 
the directional sources, and s(t) is a time-varying signal. The sampled sensor signals, 

10 represented by a function of time r(t), are input to the preprocessing computer until a 
complete block of data has been received. While the block is being further processed, 
another block of data is input to a buffer in the computer (not shown). As indicated at 
180, each block of data is first subject to computation of an array covariance matrix for 
the current block of data. The sample covariance matrix R from N samples or 

15 "snapshots" of data is given by: 

R = -^Zr(0r"(0 • 

As indicated at 182, a further important step in preprocessing is eigendecomposition, 
which decomposes the covariance matrix as: 

R = EAE", E"E = I M , 

20 where the diagonal matrix A=diag(X„ K) contains the eigenvalues of R (which 
are positive) in a descending order, and the columns of the matrix E consists of the 
corresponding eigenvectors. In this description, the subscript appended to the identity 
matrix I indicates its size. In the case of true statistics and with fewer sources than 
sensors (P<M), the last (M-P), eigenvalues are identical and they are equal to the 

25 noise variance X M . P+1 = ...=X M =a\ With sample statistics, the last (M-P) eigenvalues 
are different with a probability of one, and a statistical test has to be performed to 
determine the number of sources P. 
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In the presently preferred embodiment of the invention, the 
preprocessing computer uses a combination of two estimates of the number of sources, 
as indicated in block 184: the estimate determined by Akaike's Information Criteria 
(AIC) and the estimate determined by Rissanen's Minimum Description Length 

5 principle (MDL). Specifically, the preprocessing computer averages the AIC and 
MDL functions and finds the single maximizer of the average. The equations for 
making this estimation are given, for example, in a dissertation by Mati Wax submitted 
to Stanford University in March 1985, and entitled "Detection and Estimation of 
Superimposed Signals," and in particular the subsection headed "Estimating the 

10 Number of Signals," beginning on page 69 of the paper. AIC generally overestimates 
the number of sources, and MDL generally underestimates the number of sources. By 
averaging the two estimates, a good result is obtained. The averaged estimate of the 
number of sources is given as the minimizer of the cost function: 

15 After the number of sources is estimated, the preprocessor computer computes 
estimates of the eigenvectors and eigenvalues of the signal and noise subspaces: 

E = [E S ,E„], A = [A,,a V,.], ^ = jjjrjT J>* ■ 
E, and E„ are estimates of signal and noise subspace eigenvectors, respectively, and 
6 1 is an estimate of the noise power. The diagonal matrix A, contains the estimates of 
20 signal subspace eigenvalues. Once the subspaces are found, the preprocessor computer 
determines the transformation matrix T, as indicated in block 186, from: 
T = E,(A,-ct^I)- 1/2 . 

The transformation T is then applied to the sampled measurements r(t), as indicated in 
block 188: 

25 y(0 = T H r(0 = T"As(0 + T"n(r) = y,(0 + T"n(0, 

where y,(f) denotes the signal component in y(t). It can be proved that the covariance 
matrix of y s (t) is the identity matrix. This indicates that the steering vectors of the 
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sources after transformation to the P e -dimensional subspace are orthogonal to each 
other and the source powers are equalized. 

The transformation reduces the dimensionality of the sensor 
measurements from M, the number of sensors, to P e , the estimated number of signal 

5 sources. The eigendecomposition performed in the preprocessing computer is a well 
known technique, sometimes referred to as spatial prewhitening, originally developed 
for use in passive sonar signal processing. It is described in more detail in a number of 
texts on signal processing. For example, see "Detection of Signals in Noise," by 
Anthony D. Whalen, Academic Press, New York (1971), beginning at page 392. In 

10 spatial prewhitening, noise components at each sensor are assumed to correlated (i.e., 
not completely random noise). The prewhitening process operates on the noise signals 
to render them uncorrelated (i.e,. "whitened"). An alternative to eigendecomposition 
is to use covariance inversion in preprocessing. In effect, the latter process whitens 
both noise and signal components of the sensor signals and it can be at least intuitively 

15 understood that this is a less desirable approach since it renders the signals less easy to 
separate from the noise than if spatial prewhitening of the signal only were used. 
However, the present invention will still separate cochannel signals using covariance 
inversion instead of eigendecomposition as a preprocessing step. Currently, 
eigendecomposition, or spatial prewhitening, is the preferred approach for 

20 preprocessing. 

3.3 Operation of an Active Signal Extraction Port: 

A single active signal extraction port, one of the L ports 124 shown in 
FIG. 8A, is shown in detail in FIG. 11, which extends over two sheets, as FIGS. 11A 

25 and 11B. L is the number of physical ports allocated for signal extraction and is less 
than M, the number of sensors. For generality, the illustrated port is referred to as the 
kth port 124.k, and signals pertaining specifically to this port are referred to by signal 
names that include the prefix k. An "active" port is one that has been assigned 
responsibility for separating a signal from the received signal data. The functions 

30 performed in an active port are critical to the invention and are illustrated in FIG. 1 1 . 
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The active signal extraction port 124.k receives as inputs over line 130 
the preprocessed sensor data y(f). As in the preprocessing computer 120 (FIG. 7), the 
sensor signals are described as being processed in blocks, although it will be 
understood that an alternative embodiment of the invention could be devised to process 
5 the signals continuously. The principal output from the port is a recovered signal, 
designated g k (t). An important intermediate output is a vector quantity called the 
normalized cumulant vector, referred to as b k . Another important output is the 
generalized steering vector a*, which defines the directional location of the signal 
source. 

10 To highlight the (block) iterative nature of the algorithm, the quantities 

related to the mth analysis block are identified in this descriptive section by using the 
additional index m. For example, the steering vector estimate provided by the kth port 
after the mth block is processed is denoted as a t (m). The time variable t spans from the 
start of the mth block to the end of the mth block, and, with N snapshots per block, can 

15 be expressed at / e[(w-l)N + l,wN]. The quantities E, A and T are obviously 
obtained by processing the mth block of data, so, for simplicity, they are not written 
with the (m) index. 

It is both logical and convenient to begin describing operation of the 
signal extraction port at the point in time when the port has just been made active. No 

20 accurate signal has been recovered and no cumulant vector has been computed since the 
port became active. The block number being of input data is examined, as indicated at 
200, to determine whether the current block is the first block. If so, the steering vector 
a A (0) is set to an initial random vector with a unit norm. As shown in processing block 
102, the steering vector a t (m-l) is first projected to the signal subspace by transforming 

25 it into a value v t , using the transformation T, which is input to block 202 as shown. 
The steering vector projected into the signal subspace is computed as: 
v t =T\ k (m-l). 

These computed values are passed to a beamformer 204, which recovers an auxiliary 
waveform using as weights: 
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u,(0 = vfy(/)/ II v, ||. 
The scaling by the norm of y k is performed to ensure numerical stability in the 
cumulant computations. At convergence, the norm of v* should be unity (because of 
the preprocessing performed on the measurements). The auxiliary source waveform is 
5 provided to the cumulant vector computer 206, which computes sample estimates of the 
cross-cumulant vector b*, which has components defined by: 

(bj, = cum(« t (0,ii;(0,"I(0,y,(0) ,l*i*P„ 
where (b t ), denotes the ith component of b k . The asterisk indicates that the conjugate of 
the process u k (t) is used in two of the four quantities of which the cumulant is 
10 computed. The cumulant vector computer computes a fourth-order cumulant vector of 
the input signals. More specifically, the vector is the cumulant of four quantities 
derived from the input signals. An introduction to cumulants and their properties is 
provided in Section 20.4 to this specification. 

After the cumulant vector b k has been computed in the cumulant vector 
15 computer 106, the capture strength c k is computed in a capture strength computer 208. 

The capture strength computer 208 determines the convergence 
condition of a port by evaluating the degree of non-Gaussianity of the auxiliary signal 
u k (t), and the amount of change between b k and \ k . At convergence, these two vectors 
should be pointing at the same direction. The non-Gaussianity of the auxiliary signal 
20 can be determined from the ratio of its fourth-order cumulant to its squared power: 
| cum(u k (t),u k (t),u' k (t),u k (t))\ 
lk ~ (E{u k (t)u' k (t)}) 2 
Using cumulant properties, we obtain 

1 cum(« t (o,«;(o > i/;(o,v^ y (o/ 11 vjp 1 _ i vf b, \i \\ v k \\ 

^ ~ (E{u k (t)u k (t)}) 2 (E{u k (t)u k (t)}) 2 

The denominator can be computed from the auxiliary signal u k (t). Since the covariance 
25 matrix of the signal component of y(t) is the identity matrix, the denominator can be 
ignored when the signal to noise ratios (SNRs) are high enough. The similarity 
between b^ and \ k can be computed from the following: 
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llvfbj 

^ iivjiiibjr 

The capture strength c k can be determined from % k and % . One way is to let c k =^ k .r\ k . 
Alternatively, we can set c k =t, k or c k =r\ k . 

The capture strengths c k are provided to the controller unit for priority 
5 determination. The cross-cumulant vector is normalized by its norm and fed to the 
orthogonalizer: 

(b t (m)=b 4 /llb t II). 
If the active ports capture different sources, their cross-cumulant vectors 
should be orthogonal. To force the active ports to capture different sources, the 
10 orthogonalization unit uses the Gram-Schmidt procedure and outputs orthogonalized 
cumulant vectors (d vectors) to the ports. The steering vectors are determined from 
the orthogonalized cumulant vectors according to 

a 4 (m) = E,(A, -6 2 l P f 2 d k (m) = T(A S -a 2 l Pi )d k (m). 
The steering vectors are provided to the controller unit in order to 
15 determine the port that loses its signal in the event of a source drop-out or to determine 
which port will be activated in the case of a new signal. The steering vectors can also 
be used by an optional DF search unit to determine the source bearings. 

Finally, the active port determines the signal waveform from the source 
it is tracking. However, it is necessary for an active port to maintain gain and phase 
20 continuity of its recovered signal at block transitions in order to prevent block-to-block 
gain and phase modulation of the recovered signal. To accomplish this goal, we need 
to examine the properties of the algorithm in more detail. The algorithm normalizes 
the source waveforms to have unit variance and estimates the steering vectors based on 
this normalization, i.e., eCURE views the measurements as: 
25 r(f) = (AE^D)(DX ,/2 s(0) + "(0, 

where £ M is the covariance matrix of the directional sources which is diagonal since the 
sources are independent (Z„=E{s(r)s w (r)})- The diagonal matrix D contains arbitrary 
phase factors associated with the blindness of the steering vector estimation procedure. 
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Even when the sources are stationary, there can be gain (due to £„) and phase 
modulations (due to D) on the steering vectors estimates and waveform estimates. 

There are two different ways to determine gain and phase modulations 
for each block. We can compare the steering vector estimates a k (m) and a k (m-l), 
5 which should be pointing to the identical direction at convergence. Suppose, due to 
power changes and arbitrary phase rotations, the following relationship holds between 
the steering vectors: 

a k (m)=q k a k (m-l) 

where q k accounts for the gain and phase factor between the two steering vector 
10 estimates. We can estimate q k using least-squares: 

q k =* k H (m-\) ! i k (m)/\\a k (m-l)\\ 2 

Using 

a,(m) = E,(A s -a 2 I) 1/2 d k (m) 

and 

15 a A (/n-l)=E,(A,-a 2 I) ,/2 v, 
we obtain an alternative way to compute q k : 

q k = v f (A, - o 2 I) d 4 (ifl)/(v? (A, -6 2 T) y k ). 
In the mth block, the kth block scales the steering vector estimate by q k , 
relative to the previous block. Therefore, it scales the waveform estimate at the mth 
20 block by the reciprocal of this quantity. Hence we need to multiply the waveform 
estimate by q k (or by its estimate) in order to undo the scaling done by the processor, 
which is described as below: 

&(0 = &(dfy(0) = (<7X)"y(0 = wfy(0 

The second way to compute q k is to force the first component of the steering vector 
25 estimate to be unity. In this process, we simply let q k be the first component of a t (m). 
After q k is determined, w k will be determined using the orthogonalized cumulant vector 
d k (m) and q k . 



WO 98/24192 



PCT/US96/18867 



-53- 

Once a source waveform is recovered, it is available for subsequent 
processing as desired. It can be recorded or demodulated and listened to with 
headphones or loudspeakers. 

5 3.4 The Signal Recovery Controller: 

Now that the basic signal extraction method has been described and 
before proceeding to a description of the orthogonalizer function, it is logical to 
consider next how the signal recovery controller 122 (FIG. 8 A) operates because this 
affects operation of the orthogonalizer 126 and the signal extraction ports 124. As 

10 briefly discussed with reference to FIG. 9, an important function of the controller 122 
is to detect changes in the status (ON or OFF) of signal sources and to identify lost 
sources. In addition, the controller 122 maintains a priority list of ports and a related 
set of adaptation flags that indicate which ports are active. 

As shown in FIG. 13, which is spread over three pages as FIGS. 13A, 

15 13B and 13C,, the functions of the controller 122 include logic to detect changes in the 
number of signal sources, indicated by block 220, port allocation logic 222, priority 
list determination logic 224, and adaptation flag logic 226. The logic 220 to detect 
changes in the number of sources assumes that there is no more than one change in the 
number of sources from one data block to the next. The logic receives the estimated 

20 number of signals P e from preprocessing computer 120 and compares the P e of the 
previous block with the P e of the current block. The results of the comparison 
determine the value of source change flag, referred to simply as "Flag." Flag is set to 
zero for the initial block. There are three possible outcomes of the comparison for 
subsequent blocks of data: 

25 1 . If current P e = previous P e , Flag = 0 

2. If current P e > previous P e , Flag = 1 (new source ON) 

3. If current P e < previous P e , Flag =2 (source OFF). 

The Flag value is transmitted over line 228 to the port allocation logic 
222, which is called into operation only if Flag =2, indicating that a source has been 
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lost. The function of the port allocation logic 222 is to determine which of the active 
ports 124 was last processing signals from the source that has just been lost. The basic 
principle employed to make this determination is to identify which port has a steering 
vector with the greatest component in the current noise subspace. Each signal that 
5 contributes to the measurements has a steering vector that is orthogonal to the current 
noise subspace determined from the sample covariance matrix R . (In a simple three- 
dimensional space, one could think of a first signal eigenvector aligned with the x-axis 
direction and a second signal eigenvector aligned with the y-axis direction. The signal 
subspace for the two active signals includes the x-axis and y-axis directions. The noise 
10 subspace is the space defined by all remaining axes in the space. In this case, the noise 
subspace eigenvector is in the z-axis direction.) 

When a signal disappears and drops out of consideration, the current 
noise subspace then includes the space previously occupied by the signal. In the three- 
dimensional example, if the x-axis signal disappears, leaving only the y-axis signal, the 
15 noise subspace is redefined to include a plane in the x and z directions. To recognize 
which signal was lost, the port allocation unit uses the steering vector estimates from 
the previous data block (indicative of the active sources before one was lost), and 
projects these vectors into the noise subspace as defined for the current data block. 
The steering vector from the previous data block that lies completely in the current data 
20 block noise subspace, or the one that has the largest component in the noise subspace, 
is determined to be the signal that was lost between the previous and current data 
blocks. Again, using the three-dimensional example, if x-axis signal disappears and 
the new noise subspace is redefined be the x-z plane, then projection of the previous x 
and y signals into the current noise subspace results in a finding that the x-axis signal, 
25 lying wholly in the current noise subspace, is the signal that was lost. 

More specifically, the logic 222 obtains the steering vector estimates 
from all of the ports that were active in the previous data block, and normalizes them 
(i.e., scales them have a unit norm). Steering vector estimates are obtained for only 
the first + ports in order of decreasing capture strength. The port allocation 
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logic is concerned with the direction of the steering vectors in space and any 
differences in magnitude arising from different signal strengths should be eliminated. 
Then the normalized steering vectors are projected onto the current noise subspace, as 
provided from the preprocessing computer 120 in the form of noise subspace 
5 eigenvectors E n . For example, if a^m-l) is a steering vector estimate from the kth 
port that was active in the previous block, then the port allocation logic 222 computes 
the "leakage" of the steering vector of the kth port into the current noise subspace 
from: 

||E„E M "a t (/w-l)/K(m-l)|| ||. 

10 The logic then declares the port that has the greatest leakage into the noise space to be 
inactive by setting its adaptation flag to zero. Also the port's capture strength is set to 
a value MIN, which is a system parameter set to some very low value, such as 0.001. 
It will be recalled that the capture strength is computed in each active port as described 
earlier. However, the controller 222 can overwrite the previously computed value 

15 when it is determined that a port has become inactive. 

For example, suppose that five ports are available for use, with three 
sources present in the previous data block. Port 1 was locked onto Source 3, Port 3 
was locked onto Source 1, and Port 5 was locked onto Source 2. Assume further that 
Source 3 turned off just before the current block and that the following capture 

20 strengths were determined for the previous and current data blocks: 
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In the previous data block, Port 2 and Port 4 were inactive and had their capture 
strengths set to 0.001. When Source 3 turned off, the port allocation logic 222 
determined that Port 1 had lost its signal, using the analysis discussed above. 

Inherent in the list of capture strengths is a priority list of ports (i.e., a 
5 list of port numbers in order of decreasing capture strength). Therefore, the priority 
list based on the previous data block is [3,1,5,2,4] and the priority list based on the 
current data block is [3,5,1,2,4]. The convention adopted is that, when ports have 
identical capture strengths, they are assigned priorities based on port numbers. The 
priority list determination logic 224 generates the priority list in this manner, based on 
10 the capture strength list transferred from the port allocation logic 222. The priority list 
is used by the adaptation flags logic 226 to generate a list or vector of adaptation flags. 
The adaptation vector contains L elements, where L is the number of physical ports in 
the system. In the example given above, the adaptation flags vector for the previous 
data block is [1,0,1,0,1] and for the current data block is [0,0,1,0,1]. The adaptation 
15 flags vector is supplied to multiple port signal recovery unit (124, 126, FIG. 9), and 
specifically to the signal extraction ports 124. The priority list is also supplied to the 
multiple port signal recovery unit, and specifically to the orthogonalizer 126, which 
will be discussed in the next descriptive section. 

The purpose of the priority list is to facilitate an orderly allocation of 
20 signal sources to ports, from the lowest port number to the highest. Further, when a 
signal source turns on, it is desirable that the most recently freed port be made 
available for assignment to the new signal, to provide continuity when a source turns 
off and on again without a change in the status of other sources. 

If there is a new source (i.e., Flag = l), then this unit first obtains the 
25 previous block steering vector estimates from the ports that are inactive in the previous 
block (Ports P e to L in the priority list), and normalizes them to have unit norm. It 
then projects these steering vectors onto the current noise subspace. For example, if 
a*(m-l) is a steering vector estimate from a port that was inactive in the previous block, 
then the Port Allocation Unit computes the port's leakage from (here ||a t (/M-l)|| 
30 denotes the norm of vector a^ra-l)): 
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\\E n Ey k (m-l)/\Mm-\)\\ \\ ^ 

and declares the port which has the minimum leakage as active (sets its adaptation flag 
to one) and overwrites the port's capture strength with 2 x MIN, where MIN is a 
system parameter that is nominally set to 0.001. This is done to make the newly 
5 activated port be the last in the priority list. (The capture strength of a port is 
computed by the multiple port signal recovery unit described earlier in this 
specification. The controller, however, can overwrite the computed value as described 
above.) 

10 3.5 The Orthogonalizer: 

As already briefly discussed, the orthogonalizer 126 functions to ensure 
that each port is consistently assigned to process only one signal source, which is to say 
that each active port captures a different source. The orthogonalizer 126 receives a 
normalized cumulant vector from each active port, the vector being represented by b k 
15 for the kth port. The orthogonalizer 126 outputs back to each port an orthogonalized 
cumulant vector, which is d k for the kth port. The orthogonalizer also receives the 
priority list from the signal recovery controller 122, so has knowledge of the identities 
of the active ports and their respective associated capture strengths, and also receives 
the estimated number of signals P e , from the preprocessing computer 120. 
20 The orthogonalizer forces the active ports to capture different sources by 

orthogonalizing their cumulant vectors, which, in turn, are estimates of the steering 
vectors in the dimensionally reduced space. (It will be recalled that, in the 
preprocessing computer 120, the dimensionality of the data is reduced from M, the 
number of sensor elements, to P e , the estimated number of sources.) Ideally, the 
25 cumulant vectors for active ports should be orthogonal to each other, to cause the ports 
to capture different source signals and to prevent two ports from locking up on the 
same source signal. From the priority list and the estimated number of signals P e , the 
orthogonalizer forms a P e by P e matrix Z from the active port steering vectors bfc such 
that the kth column of the matrix Z is the steering vector of the port that is the kth item 
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in the priority list. The orthogonalizer uses a known procedure known as the classical 
Gram-Schmidt (CGS) algorithm to perform the orthogonalization operation. The 
Gram-Schmidt algorithm is described in a number of texts on matrix computations, 
such as Matrix Computations, by Gene H. Golub and Charles F. Van Loan (The Johns 
5 Hopkins University Press, 1983), pp. 150-154. 

As applied to the present system, the Gram-Schmidt algorithm is applied 
to the matrix Z to obtain a decomposition of the type: 
Z = QR, 

where Q is an orthogonal matrix (Q W Q = I), and R is an upper triangular matrix. 

10 Although the Gram-Schmidt orthogonalization procedure is used because of its 
simplicity, there are alternatives that might also be used in the invention, such as QR- 
decomposition and the Modified Gram-Schmidt (MGS) procedure. After the 
orthogonal matrix Q is determined, its columns are shipped back to the ports as 
orthogonalized cumulant vectors d*. Specifically, the kth column of the Q matrix is 

15 sent back as d* to the port that is the kth entry in the priority list. Regardless of the 
method used, the effect of the orthogonalizer is to produce a set of P e cumulant vectors 
that are orthogonal to each other. 

3.6 Operation at an Inactive Port: 

20 When a port is determined to be inactive, as indicated by a zero 

adaptation flag, the port performs three simple functions, as shown in FIG. 14. First, 
its output signal gj$) is set to zero. Second, its capture strength c k is set to a minimum 
value MIN. Finally, the last steering vector a*, estimated in the port just before it 
became inactive, is stored in a memory device associated with the port, to facilitate 

25 recapture of the same signal that was lost, if it should turn on again in the near future. 
More specifically, the adaptation flag input to the inactive port is delayed by one data 
block time. Then, using the delayed adaptation flag, the port stores a steering vector 
either from two blocks earlier, if the delayed flag has a value of 1, or one block earlier, 
if the delayed flag has a value of zero. 
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4.0 Alternate Embodiment Using Covariance Inversion Cure (CiCURE): 

The basic cumulant recovery (CURE) system described in Section 3.0 
uses eigendecomposition in preprocessing and is referred to as eigenCURE (eCURE) 

5 for convenience. Another variant of the CURE system uses covariance inversion 
instead of eigendecomposition and is referred to as covariance-inversion CURE 
(CiCURE). CiCURE is best thought of as a low-cost approximation to the high- 
performance eCURE system. As such, it shares most of the same advantages over 
standard CURE as the eCURE method. 

10 Certain conditions must be met in order for CiCURE to mimic eCURE 

and realize the same advantages. The conditions are: 

• Sensor noises must be additive Gaussian noise (eCURE assumes 
independent, identically distributed, additive Gaussian noise). 

• Received signal powers must be much greater than the noise. 

15 • Sample covariance matrix and its inverse used by CiCURE must be accurate 

enough to prevent leakage into noise subspace. 

Under stationary or steady-state signal conditions, this implies a need for 
a sufficiently long processing block size. Under these conditions, the prewhitening 
transformation used in CiCURE is a good approximation to that used in eCURE, and 

20 the two systems have similar performance properties. This section of the specification 
describes the components of a signal separation/recovery system that is based on the 
CiCURE algorithm. 

The CiCURE signal separation/recovery system incorporates a spatial 
prewhitening transformation based on the inverse of the input sample covariance matrix 

25 (this operation is performed by using an eigendecomposition in the eCURE). The 
received signal data is filtered or transformed by the prewhitening operation in the 
CiCURE, unlike eCURE. The prewhitening done in the CiCURE is implicit in the 
mathematics of the signal recovery ports, and it is only necessary to compute a matrix 
decomposition of the input sample covariance matrix. This latter operation is done in a 

30 preprocessor, whose output is made available to all of the signal recovery ports. Key 
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characteristics of the implementation described below are that the iterative convergence 
of the CURE algorithm is realized over several blocks instead of within a single block, 
and "high-priority" ports converge sooner than "low-priority" ports. 

A signal recovery system based on the CiCURE method is simpler than 

5 one based on the eCURE. There are two main architectural components to the method: 
a preprocessor unit which computes a matrix decomposition and a set of signal 
recovery ports hierarchically arranged. 

In addition, there can be two optional units: demodulators, to complete 
the recovery of the separated signal for the purpose of recording or listening, and a 

10 direction-finding (DF) search unit to provide copy -aided DF. 

A block diagram for an overall signal recovery system based on the 
CiCURE method is shown in FIG. 15. The details of the preprocessor 120' and the 
signal recovery ports (124.1, 124.2, etc.) that are unique to the CiCURE method are 
described below. All other system details are as previously described for the eCURE 

15 system. 

The preprocessor 20' computes a matrix decomposition of the input 
sample covariance matrix. It does this on a block-by-block basis by first computing the 
sample covariance matrix of the array snapshots within a processing block and then 
computing the Cholesky decomposition of the sample covariance matrix. The Cholesky 
20 decomposition is output to the signal recovery ports 124.1, 124.2, 124.3, which use 
this information to adapt their weight vectors to separate the cochannel source signals. 

The signal model for the narrowband array case is described by the 
following equation: 

r(0 = As(0 + n(0 5 
25 where r(t) denotes the array signals collected by M sensors. 

We assume that for each block N snapshots are collected for analysis 
and that there are P sources contributing to the measurements. We also assume that the 
measurement noise, n(t), is spatially white and noise power at each sensor is identical 
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but unknown and it is denoted by a 2 . The preprocessor 20' first forms the sample 
covariance matrix from the snapshots according to: 

After forming the sample covariance matrix, the Cholesky decomposition is performed: 

5 R = LL" t 

where L is a lower triangular matrix with positive diagonal terms. L is sent to the 
signal recovery ports 124.1, 124.2, 124.3, as indicated in the drawing. 

In the CiCURE structure, there is no controller unit to detect source 
ON/OFF transitions as in the eCURE system. The signal recovery ports have a 

10 predetermined hierarchy or priority order. The first port has highest priority and so 
on. Therefore, CiCURE is not able to compensate for dynamic changes in the signal 
environment as can the eCURE algorithm. Each port receives as input the current 
block steering vector estimates from the ports that are higher in priority, the sensor 
signal data, and the Cholesky decomposition of the sample covariance matrix for the 

15 current block. Each port outputs the recovered signal and associated steering vector 
for a captured source. 

FIG. 16 shows the operations of a single signal recovery port. Suppose 
the higher-priority ports produce a set of steering vectors for the current block, defined 
as {a^m), ... , a M (m)}. The weight vector to produce p k (i) for the current block (the 

20 mth block) is determined by modifying the MVDR weights for the kth port on the 
previous block by a computation carried out in the kth port as described next. The first 
step is to compute Gram-Schmidt orthogonalized weights (y k (m)) according to: 

k-\ 

v t (i»i) = w ik (ifi-l)-2(»"(w)w 4 )a l (ifi)/ || a,(w) || 2 . 

The port then uses the Gram-Schmidt orthogonalized weights (v k (m)) to determine the 
25 waveform p k (t) according to 

P*(0 = v?(m)r(0. 
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Next, a vector, a k (m), of sample cross-cumulants involving this waveform is computed 
having components: 

[a t 0»)], = cumQij (/),/>; (0»A(0.r / (/)) > 1 </ < M, 
in which, [a^m)], is the /th component of a t (m). This vector provides an estimate of a 
5 source steering vector and is sent to all the ports that have lower priority than the kth 
port and the optional direction-finding unit. In addition, the MVDR weight vector for 
the kth port is determined using a k and L. 

The MVDR weight vector is computed in a two-step procedure that 
exploits the lower triangular structure of the Cholesky decomposition. First, the 
10 temporary solution, is computed by solving the linear system of equations: 
Lu A (w) = a k (m). 

Next, the MVDR weights are computed by solving the second linear system: 

L"w A (m) = u t (m)/ II u k (m)W . 
It is necessary to maintain phase continuity with the weights of the previous block. 
15 This requirement resolves the complex phase ambiguity inherent in the blind signal 
separation problem, which would otherwise cause "glitches" in the recovered signals at 
the block boundaries. Therefore, before using the weight vector w k (m) estimate the 
signal waveform, the complex phase ambiguity is resolved by computing the scale 
factor: 

20 c k (m)=w k (m)w k (m-l)l\w k (m)w k (m-l)\ 

and then scaling the MVDR weights according to: 

^ k (m) = c k (m)w k (m) 

This operation forces the current and previous block signal extraction weights to have a 
real inner product (i.e., no abrupt phase rotation at the block boundary). This method 
25 eliminates block-to-block phase discontinuities, leaving only a bulk phase rotation 
ambiguity that is constant over all blocks recovered by the port. This bulk phase 
rotation is unimportant to the recovery of analog AM and FM modulated signals; 
however, for digital modulations, its removal is desired. Section A subsequent section 
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on phase rotation equalization presents a method for doing so. For now, we skip over 
this minor detail. 

Using the modified MVDR weights, the waveform estimate is computed 

according to: 

5 &(0 = wfr(0 

The recovered waveform is available for subsequent processing, which 
may consist of recording of the predetected waveform, demodulation, signal 
recognition, or other operations. 

The current block weights are fed into a one-block delay unit which 
10 makes them available to the Gram-Schmidt orthogonalization unit as the initial weights 
for processing the next block. Key characteristics of this implementation are that the 
iterative convergence of the CURE algorithm is realized over several blocks instead of 
within a single block, and high-priority ports converge sooner than low-priority ports. 

15 5.0 Alternate Embodiment Using Pipelined Cumulant Recovery (pipeCURE): 

This section describes a variant or extension of the eigendecomposition- 
based CURE (eCURE) system, which will be called the pipelined eigenCURE 
(pipeCURE) system. The eigenCURE (eCURE) algorithm analyzes measurements on 
a block by block basis and has dynamic capabilities to eliminate port switching and port 

20 allocation in the case of transient sources. Received signal data are filtered or 
transformed by a prewhitening operation before reaching cumulant based signal 
separation processing. eCURE (described in Section 3.0) has several advantages over 
the covariance-inversion CURE (CiCURE) (described in Section 4.0), which uses 
covariance-inversion instead of eigendecomposition: 

25 • It has better signal separation performance (i.e., better crosstalk rejection at 

port outputs). 

• It has guaranteed fast convergence, specifically a superexponential 
convergence rate which is mathematically guaranteed. 

• It has improved port stability which helps minimize random port switching. 
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• It can operate with a much wider range of input signal strengths. 

This last property is particularly useful when trying to recover a weak 
signal in the presence of strong interfering signals. 

The pipeCURE system "pipelines" the eCURE algorithm in order to 

5 have: 

• Simpler implementation (no feedback between operational blocks). 

• An ability to iterate more times over one block of data. 

• An option to use further eigendecompositions to improve results. 

10 5.1 Overview of the pipeCURE Signal Separator: 

The pipeCURE signal separator has three main components, which are 
shown in FIG. 17: a preprocessor unit 120, which is basically the same as in the 
eCURE system, a cumulant matrix computer 240, and a multiple port signal recovery 
unit 242. In addition, there are two optional units: the demodulators 128, to complete 
15 the recovery of the separated signals for the purpose of recording and the direction- 
finding (DF) search unit 172 to provide copy-aided directions of arrival on output line 
174. 

5.2 Preprocessor Unit: 

20 The preprocessor 120 performs a block-by-block analysis of the element 

array snapshots, determining the eigenvectors, number of signal sources, and signal 
subspace of the received array measurement data. It filters the received array data, 
transforming it from the M-dimensional sensor space to the P-dimensional signal 
subspace. In so doing, the steering vectors of the transformed sources are made 

25 orthogonal to each other in the range of this projection, and the transformed source 
powers are made equal (at high signal-to-noise ratios). The details of the preprocessor 
operation were described in Section 3.0 in relation to the eCURE system 
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5.3 Cumulant Matrix Computer: 

In this section, we introduce the cumulant matrix computer, a unit that 
computes the statistics as required by the iterative blind signal separation processor. 
The cumulant matrix computer computes a x P^ (here we assume the number of 
5 sources and its estimate are identical) cumulant matrix C is defined as: 

C(P ■ (i - 1) + j, P ■ (k - 1) + /) = cum(y ; (/), y , (t),y k (t),y] (/)) \<i,j,k,l<P 

With finite samples, this matrix can be estimated as: 
c(P-(/-l) + y,/ > -(^-l) + /)=^X;y;(/)y J 0)y A 0)y;(O 

10 N r,-l 

- 1 ^Zy;(' 1 >.('.EyX' 1 >;(' 1 )-^Zy;(',>;(',)tyX' ! >.(0 

N /,=1 ( 2 =1 iV <,=1 '2=1 

\<i,j,k,l<P 
in which the signal vector y(t) is defined as: 
y(r) = T"r(0, where T = E s (A s -a n 2 l)" 1/2 = US -1 

5.4 Multiple Port Signal Recovery Unit: 

15 The multiple port signal recovery unit 242, receives as inputs the 

preprocessed array measurement y(t), the cumulant matrix C the eigenstructure (E, A) 
derived from the array measurements in the preprocessor 120 and the estimated number 
of sources (P e ) generated in the preprocessor. Using these input signals, the multiple 
port signal recovery unit derives recovered signals for output on lines 132 and steering 

20 vectors for output on lines 170, in accordance with the following equations and steps: 
(a) Inputs to multiple port signal recovery unit: 

• Number of sources, P. 

/ 2 y 1/2 

• Transformation matrix T = E s [A s - a n I ) 
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• Preprocessed signals: y(/) = T H r(/) 

• Eigenstructure of the co variance matrix : {e s , A s , a* } 

• Initial estimates of the steering vectors for sources stored as the 
columns of A . 

• Cumulant matrix C: 

c(p ■ a -\)+j,p-(k-\) + /)= cum( y ;(0,y,(0,yA Q),y] (0) 1 * UjXi * p 

(b) Outputs from multiple port signal recovery unit: 

• Estimated steering vector A that will be used in the next block as a 
starting point (in place of A ). 

• Recovered signals for the analysis block , s(0 . 



15 (c) Processing in the multiple port signal recovery unit: 

1. Transformation of Steering Vectors: Project the steering matrix 
estimate onto the reduced dimensional space by the transformation matrix T: 

B = T H A 

2. Cumulant Strength Computation: Normalize the norm of each 
20 column of B and store the results in V , and then compute the cumulant strength for 

each signal extracted by the weights using the matrix vector multiplication: 
v m = b m / ||b m ||, where v m (b m ) is the mth column of V (B). 
O m = | (v* ® \ m )" C (v^ ® v„,)|, for 1 < m < P. 

3. Priority Determination: Reorder the columns of V and form the 
25 matrix W , such that the first column of W yields the highest cumulant strength, and 

the last column of W yields the smallest cumulant strength. 

Columns of V in descending cumulant strength -> W 
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4. Capture of the kth source: Starting with the kth column of W, 
proceed with the double power method followed by Gram-Schmidt orthogonalization 
with respect to higher priority columns of W , i.e., for column k: 

yy k (b + 1) = a ft+1 • (w' k (b) ® l P C (w* (b) ® \v k (Z>)) b is the iteration number, 
5 where the constant a&+ 1 is chosen so that the norm of \v k (b + 1) is unity and b is the 
iteration number. This operation is followed by the Gram-Schmidt orthogonalization: 

w A (b + 1) = P A+1 • (w t (b + 1) - X w, • (wfw, (b + 1))], since |w,| = 1, 

where the constant p A+1 is chosen so that the norm of w t (b + \) is unity. In the last 
expression, w ; denotes the final weight vector with source of priority /. 

10 5. Capture of the remaining sources: Repeat step 4, for each column for 

a predetermined K times. After iterations are complete for the kth column, declare the 
resultant vector as w k , and proceed with the remaining columns. After all sources are 
separated, form the matrix W that consists of w/s as its columns. 

Converged weight vectors w*' s -> form the columns of W . 

15 6. Port Association: After all the power method and Gram-Schmidt 

iterations are complete, we compare the angle between columns of W and the columns 
of V. 

Calculate the absolute values of the elements of the matrix Z = W" V . 
Take the arccosine of each component of Z. 
20 To find the port number assigned to the first column of Win the 

previous block, simply take the index of the largest element of the first row of the 
matrix Z. 

For the second column of W , we proceed the same way except this time 
we do not consider previously selected port for the first column. Using this rule, we 
25 reorder the columns of W , such that there is no port switching involved. 

Reorder the columns of W, based on Z -» results in V . 



WO 98/24192 



PCT/US96/18867 



-68- 

7. Steering Vector Adjustment: Due to the blindness of the problem, 
estimated steering vectors are subject to arbitrary gain and phase ambiguities. The 
gain ambiguities are corrected by the unit amplitude constraint on the columns of V . 
However, this does not prevent phase modulations on the columns of this matrix. To 

5 maintain this continuity, we compute the inner product of each column of Vwith the 
corresponding column in V and use the resulting scalar to undo the phase modulation, 
i.e., 

s m = angle(v"v„), and v„, = v„, -exp(-./eJ. 

8. Backprojection: In order to use the current steering vector estimates 
10 for the next processing block, we need to backproject the steering vector estimates for 

the reduced dimensional space to the measurement space. This yields the estimate of 
the steering matrix and can be accomplished as: 

A = E f (A s -<? 2 I / ,) +1/2 V. 

A will be used in the next block as A as an estimate of the steering matrix in the first 
15 step of the multiple port signal extraction unit. 

9. Beamforming: It is important to note that beamforming for P sources 
requires a matrix multiplication of two matrices: the V matrix that is P by P, and the 
reduced dimensional observation matrix y(t), which is P by N, where N is the number 
of snapshots. Usually N is larger than P and this matrix multiplication may take a 

20 long time because of its size. Therefore, it may be appropriate to do final 
beamforming in another processor since it does not introduce any feedback. Final 
beamforming is accomplished as: 

s(0 = V w y(0 

The estimated signals will be sent to the correct post processing units because of the 
25 orderings involved. 
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6.0 Steering Vector Tracking Method For Situations Having Relative Motion: 

For situations in which there is relative motion of the source, receiving 
array, or multipath reflectors, it is desirable to generalize the CURE algorithms to 
exploit or compensate for the motion. One rather complicated way of doing this is to 
5 use an extended Kalman filter to track the changes in the generalized steering vectors 
derived by the CURE algorithms. Here we present a simpler method which merely 
involves using a variant of the iterative update equation used in the CURE algorithms. 
We present two such variants of the update equations, called a-pCURE and [iCURE, 
that can be used principally to provide an improved initial weight vector for each block 
10 of array samples (snapshots). These update equations can be used with any of the 
CURE algorithms discussed in previous sections (CiCURE, eCURE, pipeCURE). 
Consequently a-pCURE and uCURE are not independent stand-alone algorithms, but 
rather are enhancements to CiCURE, eCURE, and pipeCURE that provide greater 
stability and less port-switching in dynamic situations. 
15 The iterative update equations are given by: 

w H1 = aw t + p vect[cum(.,.,.,.)] (a-pCURE) 
yr k+ , = On) vr k + \i vect[cum(. ,.,.,.)] (uCURE) 
= w t + |i [vect[cum(.,.,.,.)] - wj . 
These iterative update equations may be compared to the standard iterative update 
20 equation presented in previous sections for CiCURE, eCURE, and pipeCURE. 

w t+1 = vect[cum(.,.,.,.)] . (CiCURE, eCURE, pipeCURE). 

In these equations, & is a time index, and w t is the linear combiner 
weight vector that converges to the generalized steering vector of one of the input 
source signals. The iteration on the index k is on individual snapshots or block of 
25 snapshots occurring through time, as opposed to multiple iterations within a block. The 
a-p and [i update method does not preclude iteration within a block. Indeed, within- 
block iteration can be used in conjunction with block-to-block updating or 
initialization. Generally, there is no advantage to using the a-p or \x update equations 
for within-block iteration. Within-block iteration should be done by the standard 
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update equation. The a-p and \i update equations are best used for block-to-block 
updating, that is, to initialize a block's weight vector based on the final converged 
weight vector from the previous block. 

Two equivalent forms are given for the uCURE update equation. As is 

5 discussed below, the first form is most convenient when the purpose is to predict 
ahead, whereas the second form is most convenient when the purpose is to average 
previous data with new data. Although a-pCURE and uCURE appear to involve 
different update equations, the algorithms are equivalent provided there is a 
renormalization of the weight vector at every iteration. Because a weight vector 

10 renormalization is always used in the iterative steps to prevent the weight vector from 
shrinking monotonically, a-p CURE and uCURE are equivalent. 

a-pCURE and pCURE updating can be used for determining the initial 
EGSV(s) of a block of samples subject to eCURE or pipeCURE processing. When 
used with eCURE, the block initialization can be performed in either the M- 

15 dimensional sensor space or the P-dimensional signal subspace. FIG 19 and FIG 20 
show these two cases, respectivly. The application of a-pCURE and [jCURE to 
CiCURE is similar to FIG 19 but is not shown. 

FIG. 19 shows the relations among various vectors in one cycle of the 
uCURE update operating in the M dimensions of the sensor space. Five vectors are 

20 shown, w* is the current weight vector at time k and is also the current estimate of the 
generalized steering vector a*. The generalized steering vector at time k+l is denoted 
a k+1 . n k+l is the generalized steering vector of which w k+1 is an approximation. The 
cumulant vector cum = vect[cum(.,.,.,.)] is represented as a vector emanating from 
the origin. The scaled difference vector |i[cum - wj is shown as a vector originating 

25 at the tip of and extending through the tip of cum. The tip of this vector defines 

For the case shown, \i is greater than unity, and the algorithm is 
anticipatory. This form of the uCURE update is useful when the purpose is to predict 
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a generalized steering vector that is varying with time. It is instructive to think of the 
uCURE update as an equation of motion: 

New Position = Old Position + Velocity x Elapsed Time, 
where New Position is identified with w k+1 ; Old Position is identified with w k ; Velocity 
5 is identified with [cum - wj; and Elapsed Time is identified with \i. 

Conversely, if \x is less than unity, the uCURE update functions as an 
averager rather than a predictor, putting weight (1-u.) on the current weight vector 
and weight [i on cum which is an estimate of the generalized steering vector a k+l (or its 
projection b A+1 ). In this case, the tip of cum would lie to the right of w* +1 , and the 
10 scaled difference vector u,[cum - wj would point to, but not pass through, cum. 

FIG. 20 similarly shows the vector relations for one cycle of the 
uCURE update when the iteration is performed in the P dimensions of the signal 
subspace. The vectors are similar to those in FIG. 19 with the key difference being 
that b* is the projection of the generalized steering vector a* into the signal subspace, 
15 and vf k+i approximates b k+l , the projection of a t+1 . At the conclusion of the iterations, 
the estimated generalized steering vector may be obtained by backprojecting the 
terminal weight vector w into the M dimensional sensor space. 

a-fi and u- iterative updating has an advantage in the situation where 
signal sources are persistent but moving (i.e., non-static geometry). CiCURE, 
20 eCURE, and pipeCURE are formulated in the batch-processing mode (i.e., array 
snapshots are processed one block of samples at a time) assuming the source geometry 
is static during a block. With these algorithms, only small changes in source geometry 
are allowed to occur from one block to the next. a-J3 CURE and uCURE 
accommodate greater changes from block to block by providing for tracking of the 
25 generalized steering vectors via the a-p tracking method, which is well known in the 
sonar and radar engineering literature. 

In summary, ct-pCURE and \x iterative updating have tracking 
capability inherently built in which can be used to improve the performance of 
CiCURE, eCURE, and pipeCURE in situations in which EGSVs are changing 
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dynamically. This tracking capability enables the adaptation to geometrical changes 
that occur gradually over time. Abrupt changes, like the appearance of new signals or 
disappearance of old signals, and attendant port switching are a different problem. 
Detection logic is still required to mitigate port switching caused by abrupt changes. 

5 

7.0 Alternate Embodiment Using Direct or Analytic Computation: 

Unlike the iterative methods presented in previous sections, this section 
presents a method for separating signals that is non-iterative. It is, in fact, a closed 
form, analytic solution for computing the cumulant vectors and generalized steering 
10 vectors without the need for iteration. Because the method is non-iterative, the issues 
of convergence and convergence rate are no longer of concern. Convergence is both 
assured and instantaneous. 

In the direct method, the generalized steering vectors for a small number 
of sources (two in this example) are computed directly as set forth below, using one of 
15 two computational methods: 

Steps of Operation for Method 1 : 

• Compute the covariance matrix R for M channel measurements: 

R4S r(,)r " ( ' ) 

20 • Compute the eigendecomposition for R: 

R = E,A,Ef +a„ 2 E„Ef 

• Compute the transformation matrix T: 

T = EXA,-a„ 2 l)- 1/2 

• Preprocess the measurements by the transformation matrix: 
25 y(/) = T"r(0 

• Compute the four by four cumulant matrix C from y(0 : 

C(P • (i -\) + j,P-(k-\) + /)= cum(^ (t), yj (t),y k (t),y,(tj) 1 * UiXl < 2 
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• From its definition, the C matrix can be decomposed as: 




in which the three matrices {C„,C 22 ,C 21 } are defined (because of prewhitening and 
5 circular symmetry assumption): 

[ E{\ y[ (t)\ 4 }-2 E{\y,(t)\ 2 y] (t)y' 2 (t)} Jc, c 2 l 

11 [E{\ yi (t)\ 2 y 2 (0ym E{\ yi (t)\ 2 \y 2 (t)\ 2 }-\\ W 2 c 3 J 
r \E{\ yi (tf\ y2 (t)\ 2 }-\ £<h(o|V,(0*(0>lfa c 5 l 

10 22 1^MW;(0} E{\ yi {t)\'}-2 J [c's c 6 \ 

• Construct the fourth-order polynomial in terms of the complex variables {v v v 2 } . 

Vl |v 1 | 2 (c l V 1 +C 2 V 2 )+|v 2 | 2 (c 3 V 1 +C 5 V 2 )+V|V 2 (c 2 V 1 +C 4 V 2 )+V 2 V 1 ( C 2 V 1 + C l V l) 

v 2 |v,| 2 (^v, +c 3 v 2 )+|v 2 | 2 (c 5 v, +c 6 v 2 )+v;v 2 (c 3 v, +c 5 v 2 )+v 2 'v, (c>, +c' 5 v 2 ) 

15 This requires the computation of the cumulants {c,,---.c 6 } defined in the above item 
from the measurements. 

• Solve the polynomial for {v,,v 2 }. There is one trivial solution {v l =v 2 = 0}. Also 
note that if the vector (v u v 2 ) T is a solution, then the vector (-v 2 ,v,) r is also a 
solution. 

20 • Evaluate the resultant cumulant strengths from the solutions to the polynomial: 
|(v*®v)"c(v*®v)|, v = [v„v 2 ]". 



e{\mo\ 2 y^y'iV)) E{( y] (t) y ' 2 (t)) 2 }^ 
£{h(0flM')f}-i E{ y ,(t) y ' 2 (t)\ y2 (t)\ 2 }_ 
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• Determine the solution for the polynomial that results in the highest cumulant 
strengths to estimate sources. Let this be (v p v 2 ) r . Then, (-v 2 ,v,) r is the the second 
solution. 

• For each accepted solution v, we can find the corresponding steering vector in the 
5 M dimensional sensor space: 

• Once the steering vector estimates are found as in the previous step: 

1 . Port association, and 

2. Waveform continuity, 

10 can be implemented as described in Section 5.0 (pipeCURE). 



Steps of Operation for Method 2 

• Compute the co variance matrix R for M channel measurements: 

R = ^I>(0r"(0 

15 • Compute the eigendecomposition for R: 

R = E,A,E? + cr 2 E,, E " 

• Compute the transformation matrix T: 

T = E j (a,-o-„ 2 i)~' /2 

• Preprocess the measurements by the transformation matrix: 
20 y(0 = T"r(0 

after which the measurements take the form: 

y(0 = T w r(0 = b 1 5 1 (0/a 1 2 +b 2 ^ 2 (0/a 2 2 +e(0 

Because of prewhitening, we have the following result for the steering vectors for the 
25 two sources in the two dimensional space: 

■>.=[ s r e "} «-[-t:r} ikiihkii^. 1^.1=0. 
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Construct the three by two matrix F using five of the six cumulants: 

£{|M0|V2 E{\y,(tf yi (t)y;(t)} 
E {\y, (ttf y 2 (t)yl (0) E {| v, (tf \y 2 (t)\ 2 } - 1 
E{(y\ (f)y 2 (0) 2 } E {y\ (t)y 2 (t)\y 2 {tf } 

which can be decomposed into the following three matrices: 



1 

sine € * 

cosQ 


• 1 

_cos9 
sinB 


r Y4., 4 

- — rr-cos 


3 0 


" 1 ^e-* " 

cose 
i _~2§L e ->» 

L sine 


VcosG ) 






H 









F = GDH 

5 • Also form the four by four cumulant matrix C: 

C(P ■ (i - 1) + j, P ■ (k - 1) + /)= cum(^; (t), yj (t),y k (t),y', (f)) 1 ^ < 2 

The symmetries involved in this matrix reduces the number of distinct cumulants to 
six. In addition, five of the six cumulants necessary are already computed when we 
formed F. 

10 • Compute the Singular Value Decomposition (SVD) of the matrix F: 

1. If the rank of F is zero, then source separation is not possible. 

2. If the rank of F is one, then the principal eigenvector can be used to 
separate sources: assume e, is the principal eigenvector of F, and let its 
components are defined as: 



|a,| 2 +|a 2 | 2 +|a 3 f =1 
stimate o1 

■[::]"' 



Then, we can obtain the estimate of the first source, using: 
and the second source waveform can be estimated using: 
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ft(0 = 



y(0 



3. If the rank of F is two, then the null eigenvector can be used to 
separate sources together with a solution of a quadratic equation: let x denote 
the 3 by 1 vector that is orthogonal to the columns of of F (which can be 
obtained using SVD or QR decomposition of F): 
x"F = 0, \ = \x l ,x 2 ,x 3 J 



Then, due to the Vandermonde structure of the columns of G, we can obtain the 

fsinG ,.. cosG , „ , , . 

parameters 1 — -e 7 * ,-— -r > , as the roots of the quadratic equation: 
[cosG sin 6 J 

x"z = 0, z= [z,,z 2 ,z 3 J -» x* + x 2 z + x 3 V = 0 
Since we know the roots of the above equation should be 

e Ji> - C ° S ^ e A \ , and we have the weight vectors to separate the sources 
cosG sin9 J 



r,(0 = 



ft(0 = 



sin9 
— r e 
cosG 



sinG 



y(0 = 5, (0 / (a, 2 cosG) + 0 • s 2 (t) + 



sinG 

re 

cosG 



e(0 



y(0 = s 2 (t)e~* I (a 2 2 sinG) + 0 • s, (t) + 



sinG 



e(0 



In addition, we can normalize the weights to conform to the structure of the 
problem: 



v,=P, 


1 

sinG lVk 




1 

_ cosQ e « 




e JV 

.cosG 




sinG 
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in which {p,, p 2 } are determined to make IvJ = |v 2 || = 1 . 

• After the weights for signal separation are determined, then it is possible to 
compute cumulant strengths using: |(v* ® v) W c(v* <8> v)|, v = [v,,v 2 ] w is one of the 
weight vectors. 

5 • For each solution represented byv, we can find the corresponding steering vector in 
the M dimensional sensor space: 

a = E s (A,-o-,0 ,/2 v 

• Once the steering vector estimates are found as in the previous step: 

1 . Port association, and 
10 2. Waveform continuity 

can be implemented as described in Section 5.0 (pipeCURE). 



8.0 Separation Capacity and Performance When Overloaded: 

When the number of incident signals exceeds the capacity of the system 
15 to separate signals, one would expect system performance to degrade. Unlike some 

other cochannel signal separation methods, the present invention is able to operate 

under such overload conditions. 

Cochannel signal separation systems are designed to be able to separate 

and recover signals provided the number of cochannel signals incident on the array 
20 does not exceed a number that defines the separation capacity of the system. In the 

present invention, the separation capacity is equal to the number of sensors M in the 

receiving array. Consequently, a cochannel signal separation system based upon this 

method can have no more than M output ports. Of course, the number of output ports 

can be less than M. For instance, a system can have P output ports, where P<M. In 
25 this case the system could recover each of P signals from among M signals incident on 

the array. Each of the P signals is recovered by a different set of beamformer weights. 

Each such set or weight vector defines a sensor directivity pattern having M-l nulls. 

Next consider cochannel signals received at the receiving array 

consisting of a mixture of coherent and noncoherent multipath components. A 
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complete description of how CURE algorithms behave in the presence of multipath is 
given in Section 9.0. In brief, signals with noncoherent multipath components are 
recovered on more than one output port. Each output port is associated with a single 
generalized steering vector. The system of the invention automatically creates groups 
5 of mutually coherent multipath arrivals and a different generalized steering vector is 
formed for each such group. Each group is treated as an independent signal and counts 
as one signal against the capacity M. The maximum number of such noncoherent 
groups that can be incident on the array for which the system can perform separation 
and recovery equals the separation capacity. In the present invention, this capacity 
10 equals the number of array elements M. 

In overload situations, the cumulant optimization or iteration, which is 
the basis of the invention, still converges to a generalized steering vector of a signal or 
noncoherent multipath group. Consequently, the system of the invention determines up 
to M generalized steering vectors from which beamforming weights are computed and 
15 which can form up to M-l generalized nulls. However, because the number of signals 
is greater than capacity, it is not possible to recover a given signal while 
simultaneously rejecting all other signals by means of generalized nulls. In particular, 
there are P-M excess signals (or G-M noncoherent groups) that leak through the 
beamformers for the recovered signals. These excess signals are rejected merely by 
20 the sidelobe suppression associated with each beamformer's directivity pattern. The 
signals that are captured for recovery by the system tend to be the strongest signals, 
while the excess signals tend to be among the weakest. The excess signals contribute 
to the noise floor of the output ports. However, their contribution is minimal because 
of their low relative power and the sidelobe attenuation. Consequently, the recovered 
25 signals at the output ports generally have low crosstalk levels and high signal-to- 
interference-plus-noise ratio (SINR). 

FIGS. 21 and 22 illustrate the overload concept diagrammatically. FIG. 
21 shows a basestation having a four-element antenna array, which provides input 
signals to a CURE system for separating received cochannel signals. Because the 
30 antenna array has only four elements, the system has a capacity of four channels. The 
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figure also shows five users, designated User A, User B, User C, User D and User E, 
all attempting to transmit signals to the basestation array. FIG. 22 shows a directivity 
pattern associated with the antenna array as conditioned by the CURE system to 
receive signals from User A. Because the array has only four elements, it can present 
5 directivity nulls in only three directions. In the example, the directivity pattern presents 
a strong lobe in the direction of User A, to receive its signals, and presents its three 
available nulls toward User B, User D and User E. User C, which produces the 
weakest and most distant signal, cannot be completely nulled out. Similar directivity 
patterns will be generated for receiving signals from User B, User D and User E. In 
10 each case, the weakest signal (from User C) will not be completely nulled out by the 
directivity pattern. The system continues to operate, however, and is degraded only in 
the sense that weaker sources exceeding the system capacity cannot be recovered and 
will produce some degree of interference with the signals that are recovered. 

A general conclusion is that the various embodiments of the invention 
15 are tolerant of separation capacity (or number-of-signals) overload conditions. In other 
words, the various embodiments of the invention are "failsoft" with respect to overload 
beyond the signal separation capacities, and the ability to separate signals degrades 
gracefully as the number of signals is increased above the separation capacity. This 
property distinguishes CURE algorithms from DF-beamforming cochannel signal copy 
20 algorithms, such as MUSIC and ESPRIT , which do not function when overloaded. 
(MUSIC is an acronym for Multiple Signal Identification and Classification, and 
ESPRIT is an acronym for Estimation of Signal Parameters via Rotational Invariance 
Techniques. For more information on these systems, see the papers cited in the 
"background" section of this specification. 

25 

9.0 Performance of the Invention in the Presence of Multipath: 

This section discusses the performance of the CURE systems (CiCURE, 
eCURE, pipeCURE, etc.) when the signal environment includes multipath propagation. 
We confine the discussion to the phenomenon known as discrete multipath, as opposed 
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to continuous volumetric scattering, which is more complicated to describe. However, 
the statements below apply to volumetric scattering under certain conditions. 

Multipath propagation occurs when a signal from a source travels by 
two or more distinct paths to arrive at a receiving antenna from several directions 
5 simultaneously. A novel feature of the present invention is its ability to separate 
cochannel signals in a multipath signal environment. 

Multipath propagation is caused by the physical processes of reflection 
and refraction. A similar effect is caused by repeater jamming, wherein a signal is 
received and retransmitted at high power on the same frequency. Repeaters are 
10 commonly used in radio communication to fill in shadow zones, such as around hills or 
inside tunnels, where the communication signal does not propagate naturally. 
Cochannel repeaters are also used in electronic warfare (EW) systems to "spoof" a 
radar system by retransmitting a radar signal with a random delay at sufficiently high 
power to mask the actual radar return. The amount of delay is set in order to cause a 
15 false distance to be measured by the radar. 

Naturally occurring multipath propagation can consist of a small number 
of discrete specular reflections, or it can consist of a continuum of reflections caused 
by scattering from an extended object. The various multipath components arriving at 
the receiving antenna will generally be somewhat different. Differences among the 
20 various multipath components of a given source signal are (1) different directions of 
arrival (DO As); (2) different time delays due to the different path lengths traveled; and 
(3) different Doppler shifts on each multipath component due to motion of the transmit 
antenna, receive antenna, or reflecting body. 

Array-based cochannel signal separation and recovery systems 
25 traditionally have difficulty working in a multipath environment (i.e., when the one or 
more of the arriving signals incident on the array come from several distinct directions 
simultaneously). For example, most multiple source DF-beamforming signal copy 
systems generally do not work properly or well in a multipath environment, and special 
techniques such as spatial smoothing and temporal smoothing must be employed to DF 
30 on the individual multipath components of an arriving signal. The resultant system and 
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processing complexities make DF-based cochannel signal recovery systems largely 
impractical for reception in signal environments characterized by significant multipath 
propagation. The cochannel signal separation capability of the CURE family of 
systems overcomes these limitations. 

5 To understand how the CURE system behaves in the multipath context 

requires understanding the different types of multipath effects and how the system 
handles each type. In general, multipath arrivals of a source signal can be classified as 
either coherent or noncoherent depending on whether the arrivals' cross-correlation 
function computed over a finite time interval is large or small. Thus the designation 

10 coherent or noncoherent is relative to the length of the measurement interval. Coherent 
multipath components frequently occur in situations where the scatterering bodies are 
near either the transmit or receive antennas and are geometrically fixed or moving at 
low velocities. Noncoherent multipath is caused by path delay differences and Doppler 
shift differences that are large compared to the measurement window. 

15 The CURE algorithms recover generalized steering vectors as opposed 

to ordinary steering vectors. An ordinary steering vector is the value of the array 
manifold at a single angle corresponding to a source's DO A. However in a multipath 
environment the received wavefield that the array spatially samples is composed of 
many plane waves for each source signal. Each source, therefore cannot be 

20 characterized by a single DO A or steering vector. We consider how the CURE 
algorithms behave under three cases: 

• Coherent multipath components, 

• Noncoherent multipath components, 

• Mixtures of coherent and noncoherent multipath components. 

25 

9.1 Performance Against Coherent Multipath: 

In a coherent multipath signal environment, the CURE system finds a 
single steering vector for each independent signal source. However, these steering 
vectors do not correspond to the ordinary steering vectors, which could be innumerable 
30 in the presence of many multipath scatterers. Rather, the CURE vectors are 
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generalized steering vectors that correspond to the sum of all the mutually coherent 
multipath components of a signal source incident on the array. In the case of a finite 
number of discrete multipaths, the generalized steering vector depends on the relative 
power levels, phases, and ordinary steering vectors of the multipath components. 

5 The CURE signal recovery process is blind to the array manifold. Once 

the generalized steering vectors for the cochannel sources have been obtained, it is 
unnecessary to convert them to source directions of arrival (DOAs) by using the array 
manifold, as would generally be done in a system employing direction finding (DF). 
Instead, the beamforming weight vectors for signal recovery are computed directly 

10 from the generalized steering vectors. This is done by one of two methods: (1) by 
projecting each generalized steering vector into the orthogonal complement of the 
subspace defined by the span of the vectors of the other sources (by matrix 
transformation using the Moore-Penrose pseudo-inverse matrix); or (2) by using the 
Capon beamformer, also called the Minimum Variance Distortionless Response 

15 (MVDR) beamformer in the acoustics literature, to determine the recovery weight 
vectors from the generalized steering vectors. These solutions are both well known in 
the signal processing engineering literature. (See, for example, pp. 73-74 of Hamid 
Krim and Mats Viberg, "Two Decades of Array Signal Processing Research," IEEE 
Signal Processing Magazine, vol. 13, no. 4, pp. 67-94, July 1996, ISSN 1053-5888, or 

20 Norman L. Owsley, "Sonar Array Processing," Chapter 3 of Array Signal Processing, 
S. Haykin (ed.), Prentice-Hall, 1985, 445 pp., ISBN 0-13-046482-1.) If the 
generalized steering vectors are determined perfectly, i.e., no estimation error, then the 
former solution would provide zero crosstalk (or maximum signal-to-interference ratio) 
among the recovered signals at the beamformer output. The latter solution would 

25 provide recovered signals having maximum signal-to-interference-plus-noise ratio 
(SINR). 

Each output port of the CURE-based system has a beamforming weight 
vector that is orthogonal or nearly orthogonal to the generalized steering vectors of the 
cochannel signals that are rejected by the output port. Each beamforming weight 
30 vector has a corresponding directivity pattern that assigns a gain and phase to every 



WO 98/24192 



PCT/US96/18867 



-83- 

possible direction of arrival. These directivity patterns can have up to AM nulls, 
where N is the number of array elements. The nulls can be either physical nulls in 
prescribed directions-of-arrival (DOAs) or, in the case of coherent multipath, 
generalized nulls. Generalized nulls are not directional nulls but rather are formed 

5 when a directivity pattern assigns gains and phases in the directions of the coherent 
multipath components of an interfering signal such that the components sum to zero. 
Generalized nulls have a major advantage over physical nulls for combating cochannel 
interference from coherent multipath because fewer degrees of freedom (i.e., fewer 
array elements) are required to cause coherent multipath components to sum to zero 

10 than are required to directionally null each component separately. 

FIG. 23 illustrates these concepts for the case of a transmission received 
over a single-bounce path, designated multipath arrival A, a direct path, designated 
■ multipath arrival B, and a two-bounce path, designated multipath arrival C. The three 
multipath components are indicated as having steering vectors of amplitude and angle 

15 combinations A, Za , A 2 Zp , and A 3 Zy , respectively. The CURE signal recovery 
system of the invention presents a directivity pattern that assigns a gain and phase to 
every possible direction of arrival. The gains and phases corresponding to the three 
multipath components in this example are shown as D, Z<t>, , D 2 Z<|> 2 , and D 3 Z<J> 3 . The 
corresponding recovered signal for the combination of multipath components is derived 

20 from signals of the form: 

y(t) = [A^.e^^'^ A 2 D 2 e j(p+ * j) + A 3 D 3 e j(Y+ * j) }(t) . 

Because the coherent multipath components of each output port's desired 
signal are optimally phased, weighted, and combined in the recovery process, the 
CURE method realizes a diversity gain in the presence of multipath in addition to 
25 eliminating cochannel interference. The amount of the gain depends on the number 
and strengths of the distinct multipaths that are combined. 
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9.2 Performance Against Noncoherent Multipath: 

Multipath arrivals of a source signal are not always coherent and capable 
of being combined. The coherency requirement for CURE is that the multipath 
components of a signal must have high cross-correlation computed over the duration of 

5 a processing block or data collection interval. Multipath coherency can be destroyed 
by large path delay differences and large Doppler shift. When this happens (i.e., when 
the multipath arrivals are noncoherent), the CURE algorithms recognize and treat the 
arrivals as independent cochannel signals. The steering vector is estimated for each 
arrival, and each arrival is separately recovered and assigned to a different output port. 

10 Thus, multiple recovered versions of the source signal are formed. It is 
straightforward to recognize a noncoherent multipath situation because the same signal 
will be coming out of two or more output ports, each with a slightly different time 
delay or frequency offset. 

FIG. 24 shows the sensor array complex directivity pattern in a situation 

15 involving receipt of two coherent multipath components of a desired signal and a non- 
coherent signal from an interference source. As indicated in the drawing, the complex 
directivity pattern includes a null presented toward the interference source, while the 
two multipath components are received and combined in the same way as discussed 
above with reference to FIG. 23. 

20 

9.3 Performance Against Mixtures of Coherent and Noncoherent Multipath: 

In the general case of both coherent and noncoherent multipath, the 
CURE algorithms automatically partition the multipath arrivals into mutually coherent 
groups, and determine a generalized steering vector for each group. As in the case of 

25 noncoherent multipath, multiple recovered versions of the source signal are formed. 
The diversity gain is diminished relative to what would have been achieved had the 
multipath arrivals all belonged to a single coherent group. However, the loss of 
diversity gain is offset by having multiple replicas of the recovered signal appear at the 
beamformer's outputs. Moreover, a post-recovery combining gain is possible by 

30 adding the signals at the output ports after correction for delay and Doppler shift. If 
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the recovered signals are to be demodulated, this post-recovery combining step would 
precede demodulation. 

FIG. 25 shows the complex directivity pattern formed by the 
beamformer of the CURE system in a situation similar to that discussed above for FIG. 

5 24, except that the desired signal multipath components are non-coherent instead of 
coherent. The CURE system treats the three arriving signals (the non-coherent 
multipath components and the interfering signal) as being from separate sources. The 
directivity pattern shown is the one that would be presented for recovery of the 
multipath component designated Arrival B. Physical nulls are presented toward the 

10 other arriving signals. 

FIG. 26 shows a slightly different situation, in which the received 
signals include a first interferor (A), a second interferor (B) having two coherent 
multipath components, and a desired signal. Interferor A is rejected by a physical null 
in the complex directivity pattern. Interferor B is rejected by a generalized null in the 

15 directivity pattern, such that the algebraic sum of the multipath arrivals of the signal 
from Interferor B is zero. If the Interferor B signal arrivals are characterized by gains 
and phases A, Za and A 2 Zp , and the directivity pattern at the angles of arrival of 
these components has gains and angles D, Ztj), and D 2 Z<t> 2 , then the necessary 
condition for rejection of the Interferor B signals by the generalized null is: 

20 A 1 D 1 e j(a+ * l) +A 2 D 2 e j(p+ * 2) = 0. 

10.0 Recovering Communication Signals In The Presence Of Interfering Signals: 

This section describes how the present invention is used separate and 
recover signals received in the presence of other interfering signals emanating either 
25 from a local "friendly" source or from a deliberately operated jamming transmitter 
located nearby. The apparatus of the invention includes an antenna array and a 
cumulant recovery (CURE) processing system, which processes signals received 
through the antenna array and produces outputs at multiple ports corresponding to the 
multiple sources from which signals are received at the antenna array. The processing 
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system converges rapidly on estimates of the desired signals, without knowledge of the 
geometry of the antenna array. 

Two primary problems in this area are addressed by this aspect of the 
present invention. In one situation, an interfering transmitter may be "friendly," that 

5 is to say operated necessarily near a radio receiver, or even on the same ship or 
vehicle. Even if the transmitter is operating on a different frequency, there is often 
"spectral spatter" into the receiving band. In a related situation, the interfering 
transmitter is not "friendly" and is much more powerful than the communication 
signals to be received and recovered. 

10 In the first case, it might be desired to listen and receive while jamming 

and transmitting simultaneously. Normally such simultaneous transmit and receive 
operations are not possible, but the friendly transmitter can be selectively turned off to 
permit reception. Prior to this invention, however, true simultaneous operation of the 
interfering transmitter and the receiver were often impossible. 

15 In the second case, where a strong jamming signal is not under 

"friendly" control, recovery of the received communication signal requires the use of a 
nulling antenna array. In the past, systems for recovering a communication signal in 
the presence of jamming required knowledge of the antenna array geometry and did not 
always provide rapid convergence on the desired signal solution.] 

20 As shown in the drawings, the present invention pertains to systems for 

recovering communication signals in the presence of interfering or jamming signals, 
whether or not on the same frequency. More specifically, as shown in FIG. 27, a 
receiving antenna 280 may be located on the same vehicle or vessel as a local 
transmitter 282, and there may be a high-powered transmitter 284 located on a nearby 

25 friendly vessel operating at the same or a different frequency. A desired signal is 
received from another transmitter 106, located on land or on another vessel, but is 
subject to interference from the high-powered transmitter 284 and from the local 
transmitter 282. In accordance with the invention, the receiving antenna 280 is coupled 
to a cumulant recovery (CURE) processing system 290, which rapidly processes the 

30 signals from the antenna array 280 and generates outputs on multiple ports, effectively 
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separating the signals received from the high-powered interfering transmitters and the 
desired received signal onto separate output channels, as indicated for ports #1, #2 and 
#3. 

As shown in FIG. 28, a related situation is one in which reception at the 
5 receiving antenna 280 is interfered with by a high-powered jamming transmitter 292, 
perhaps on an enemy vessel. As in the previous case, the CURE processing system 290 
separates and recovers the desired weak signal on one output port (#2), while the 
jamming signal is isolated and may be discarded from port #1. 

10 11.0 Diversity Path Multiple Access (DPMA) Communication: 

The blind cochannel signal separation capability of the CURE algorithms 
can be used to make possible a new communication channel access scheme: Diversity 
Path Multiple Access (DPMA). This technique enables the design of new 
communication networks that can accommodate more users simultaneously in a given 

15 bandwidth allocation. 

The demand for communication services has grown steadily over the 
past three decades. To a limited extent this demand has been offset by technological 
improvements that have made new bandwidth available at higher frequencies up to the 
optical frequency band. Such bandwidth improvements, however, have been unable to 

20 keep pace with the growing demand for communication, and new commumcation 
methods became necessary. In response, communication system engineers have 
developed new methods for communication, including networks, control protocols, 
channel access schemes, and modulation schemes. The principal goal of these 
developments is to enable more users to use and share a communication resource 

25 simultaneously without degrading the quality or creating mutual interference. 

11.1 History and Prior Art of Multiple Access Communication: 

Prior to this invention, communication engineers had six channel-access 
schemes at their disposal whereby multiple users in a network could share an RF 
30 communication channel in order to transmit simultaneously, more or less, to a central 
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receiving site (e.g., cell base station or satellite). Communication engineers would use 
any of the following schemes to enable radio communication between multiple users 
and a single or multiple base stations. For a wireless network design, a communication 
engineer would pick one or more of the following methods as the basis for the design. 
5 • Frequency division multiplexing/multiple access (FDM/FDMA) 

• Spatial division multiplexing/multiple access (SDM/SDMA) 

• Time division multiplexing/multiple access (TDM/TDMA) 

• Code division multiplexing/multiple access (CDM/CDMA) 

• Frequency hop multiplexing/multiple access (FHM/FHMA) 
10 • Angle division multiplexing/multiple access (ADM/ADMA). 

Although the terminology in this technology is still evolving, the 
following distinction is often made. If two transmissions are cooperative, in the sense 
of being part of a common communication network, the term "multiple access" is used. 
If the transmissions are independent and not part of a network, the term "multiplexing" 
15 is commonly used. The distinction is minor and we shall largely ignore it in this 
description. 

In FDMA, different transmitting users are assigned to different 
frequencies. More precisely each transmitting user is assigned a different spectral slice 
that doesn't overlap with those of other users. FDMA was historically the first 

20 multiplexing/multiple access method to develop. Its origin is traced back to the 
beginning of radio, and it is the basis for radio and television broadcast services, 
whereby an individual is able to receive and select among the signals transmitted by 
many stations. In an FDMA network, the transmitting users signals are not cochannel, 
and cochannel interference is thereby avoided. 

25 The remaining five channel access schemes enable two or more users to 

be on the same frequency at the same time (i.e., user transmitted signals can be 
cochannel). The schemes mitigate or prevent mutual interference by different means. 

SDMA is the cellular concept, which originated at Bell Laboratories 
(The Bell System Technical Journal, special issue on Advanced Mobile Phone Service, 

30 vol. 58, no. 1, January 1979). Users are divided geographically into cells, seven of 
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which are indicated at 300 in FIG. 29. Each cell 300 has a base station 302, and the 
base stations are linked together via fixed land lines 304 or point to point microwave 
links. A central facility, the mobile telephone switching office (MTSO) 306, controls 
network operation and generally serves as a gateway for tying the mobile network to 

5 other communication services such as the public switched telephone network (PSTN) 
308. The set of base stations 302 and the MTSO 306 form the "backbone" 
infrastructure of the mobile network. Each base station 302 has a finite set of 
frequencies for sending and receiving, and adjacent cells 300 have different sets of 
frequencies. Within each cell, FDMA is employed to prevent cochannel interference. 

10 There are only a finite number of frequency sets available, and base stations 302 that 
are separated by some minimum distance use the same frequency sets. Thus, two 
transmitting users, indicated at 310 that are on the same frequency are necessarily in 
different cells some distance apart. Each users signal enters the backbone through a 
different base station. The geographic distance between cells prevents cochannel 

15 interference. 

SHMA prevents cochannel interference by prohibiting intracell 
frequency reuse and allowing only intercell frequency reuse. The remaining four 
channel access schemes TDMA, CDMA, FHMA, and ADMA overcome this 
restriction and enable frequency reuse among users within a cell-intracell frequency 
20 reuse. 

In TDMA, all users transmit on the same frequency. Each transmitting 
user is assigned a unique time slot in which to transmit. The average rate of 
information transmission equals the peak or instantaneous rate times a duty factor 
which is the slot duration divided by the revisit interval. Although the users are 

25 sending at the same time, TDMA prevents cochannel interference because the users do 
not actually transmit simultaneously. 

CDMA is a form of direct sequence spread spectrum in which the 
various users encode their transmissions with orthogonal or nearly orthogonal 
spreading sequences. All transmitting users use the same frequency. In order to 

30 receive a particular signal, a receiver must despread the signal using the same sequence 
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that was used to spread it at the transmitter. Because of the orthogonality property, the 
cross-correlation between any two spreading codes is near zero. For this reason, the 
user signals after reception and despreading are free of cochannel interference. CDMA 
is the basis of the IS-95 communication standard. 

5 FHMA is used to apply frequency hop spread spectrum technology to 

communication networks. A set of frequency hopping (FH) radios operate in the same 
band on the same hop frequencies and transmit to a central receiving facility or base 
station without mutual interference provided the radios use non-interfering hop 
sequences. Unlike CDMA, the required sequence property is not orthogonality or low 

10 cross-correlation, but rather a mathematical relative of the Latin Square. FHMA can 
be thought of as a dynamic form of FDMA in which the frequency assignments change 
regularly. 

ADMA, which is shown in FIG. 30, uses multi-source direction finding 
(DF) and beamforming technology to isolate and recover the signals from the 

15 transmitting cochannel users in a cell. Each base station 302 is equipped with a 
receiving array connected to an N-channel receiver (not shown), where N is the number 
of antennas in the receive array. The received signals are processed by a multi-source 
DF system 312 to determine the directions or angles of arrival (DOAs) of the signals 
on a given frequency. Any multi-source DF algorithm can be used to perform the DF 

20 function, such as MUSIC, ESPRIT, or WSF, all of which are well known in the signal 
processing engineering literature. Each user 310 is characterized by a single unique 
DO A. Beamforming weight vectors are then computed, as indicated in block 314, 
from the estimated directions that enable the cochannel signals to be recovered 
(separated and copied). A transformation matrix, whose rows are the beamforming 

25 weight vectors, multiplies the array signals, and the product yields the recovered 
cochannel signals. Each row of the transformation matrix (i.e., each weight vector) 
consists of complex numbers that steer the array to one particular signal while putting 
directional nulls in the directions of the other cochannel signals. The transmitted user 
signals can be recovered free of cochannel interference provided the users are angularly 
30 dispersed such that they have distinct bearing angles measured at the receive array. 
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ADMA is described in a recent patent by Roy and Ottersten (Richard. H. Roy, III, and 
Bjorn Ottersten, Spatial Division Multiple Access Wireless Communication Systems, 
U.S. Patent No. 5,515,378, May 7, 1996), but the patent specification uses the term 
SDMA. 

5 

11.2 A New Method of Multiple Access Communication: 

The present invention achieves a new method for channel access in 
wireless communications that is distinct from the six basic methods described above. 
The new method is termed diversity path multiple access (DPMA). It overcomes three 

10 limitations of ADM A. 

First, wireless channels (characterized by their angle spread, delay 
spread, and Doppler spread) are dominated by multipath. The transmitting user signals 
arrive at a base station from a multiplicity of directions simultaneously. Angle spread 
arises due to multipath from local scatterers and remote scatterers. The local scatterers 

15 are near the user and near the base station. Measurements have shown that angle 
spreads for cellular channels generally lie in the range from 2 to 360 degrees. 
Therefore multipath cannot be ignored, and the idea that a user's signal arrives from a 
single unique direction is demonstrably not true. The ADMA concept of a single wave 
arriving from a single direction characterized by a pair of angles for each cochannel 

20 signal source is valid in free-space communications, perhaps, but is not valid for 
wireless communication networks operating in the ultra high frequency (UHF) band in 
urban, suburban, or rural environments. 

Second, most multi-source DF algorithms generally do not work 
properly or well in a multipath environment. Although well-known techniques such as 

25 spatial smoothing and temporal smoothing can be used to DF on the individual 
multipath components of an arriving signal, the resultant system/processing 
complexities make such approaches impractical. 

Third, even when multipath is absent, ADMA requires the transmitting 
cochannel users DOAs to be distinct. That is, the angular separation between users 

30 cannot be zero. The users must be separated in angle from one another by some 
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minimum angle. The assignment of a frequency to several cochannel users must take 
this geometric restriction into account. This limits the utility of ADMA. 

The cochannel signal separation capability of the CURE algorithms 
overcomes the limitations of ADMA. CURE algorithms recover generalized steering 

5 vectors as opposed to ordinary steering vectors. An ordinary steering vector is the 
value of the array manifold at a single angle corresponding to a source's DOA. 
However, in a multipath environment, the wavefield at the receiving array is composed 
of more than one plane wave for each source signal. Consequently, sources cannot be 
characterized unique DOAs or steering vectors. 

10 The CURE signal recovery process is blind to the array manifold. The 

CURE algorithms find, for each source, a generalized steering vector that corresponds 
to the sum of all the mutually coherent multipath components of a signal source 
incident on the array. The generalized steering vector depends on the relative power 
levels, phases, and ordinary steering vectors of the multipath components. Formally, 

15 each generalized steering vector is a complex weighted sum of the array manifold 
steering vectors at the multipath arrival directions. The complex weights account for 
path length and attenuation differences among the multipath arrivals. In some cases, 
the multipath structure consists of a continuum rather than a few discrete components. 
In such cases the generalized steering vector becomes an integral of the array manifold 

20 over all directions. The CURE system determines the generalized steering vectors 
directly from the received signals, not from the array manifold. Indeed, the various 
embodiments of the CURE system do not need the array manifold to perform signal 
separation and recovery. 

Once the generalized steering vectors for the cochannel sources have 

25 been obtained, it is unnecessary to convert them to source DOAs by using the array 
manifold, as would generally be done in a system employing DF such as ADMA. 
Using CURE, the beamforming weight vectors for signal recovery are computed 
directly from the generalized steering vectors. This is done by one of two methods: 
(1) projecting each generalized steering vector into the orthogonal complement of 
30 subspace or span of the vectors of the other sources; (2) using the minimum variance 
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distortionless beamformer (MVDR) equations to determine the recovery weight vectors 
from the generalized steering vectors. These solutions are both well known in the 
signal processing engineering literature. If the generalized steering vectors are 
determined perfectly, i.e., no estimation error, then the former solution would provide 
5 zero crosstalk (i.e., maximum signal-to-interference ratio) among the recovered signals 
at the beamformer output. The latter solution would provide recovered signals having 
maximum signal-to-interference-plus-noise ratio (SINR). 

An illustration of how the invention is used in the context of a DPMA 
communication system is provided in FIG. 31, which shows a single cell 300, with a 
10 basestation 302 and two users 310. One user (A) reaches the basestation through 
multipath propagation, while the other has a direct propagation path to the basestation. 
A CURE processing system 316 receives and processes the signals received by the 
basestation 302. In communicating with cochannel user A the system 316 generates a 
beamformer directivity pattern that presents a physical null toward the other user, but 
15 presents a generalized steering vector that results in both multipath components from 
cochannel user A being received and combined. 

A feature of the CURE systems is that the omnipresence of multipath 
enables the recovery (separation and copy) of signals from sources that have zero 
angular separation from the point of view of the receiving base station array. For 
20 example, consider two sources that are collinear with the base station such that one 
source lies behind the other. Although the direction to both sources is identical and the 
ordinary steering vectors for line of sight propagation are identical, the multipath 
configurations are entirely different. Therefore, the generalized steering vectors of the 
two sources will be entirely different. This facilitates the separation and recovery of 
25 the cochannel source signals in situations where ADMA cannot work. 

Because the coherent multipath components are optimally phased, 
weighted, and combined in the recovery process, the CURE method realizes a diversity 
gain in the presence of multipath. The amount of the gain depends on the number of 
distinct multipaths that are sufficiently coherent to be able to be combined. 
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Not all multipath components of a source will be coherent and capable 
of being combined. The coherency requirement is that the multipath components of a 
signal must have high cross-correlation computed over the duration of a processing 
block or data collection interval. Multipath coherency can be destroyed by large path 
5 delay differences and large Doppler shift. When the multipath components of a signal 
source are not all mutually coherent, the CURE algorithms automatically partition the 
multipath arrivals into coherent groupings, and determine a generalized steering vector 
for each group. When this happens, multiple recovered versions of the source signal 
are formed. The diversity gain is diminished relative to what would have been 
10 achieved had the multipath arrivals all belonged to a single coherent group. However, 
the loss of diversity gain is offset by having multiple replicas of the recovered signal 
appear at the beamformer's outputs. 

By using the multipath combining feature of the CURE algorithms, a 
new communication network channel access method is achieved: DPMA. In DPMA, 
15 the communication path that defines the link from a transmitting user to a receiving 
base station consists of a weighted combination of multipaths. The multipath 
processing capability of the CURE systems provide a practical means for implementing 
a communication network employing DPMA. The CURE algorithms determine the 
complex multipath-combining weights of a desired signal automatically, dynamically, 
20 and in real time, while rejecting the multipaths of cochannel other-user signals. 

It is important to note the difference between DPMA and ADM A. The 
orthodox ADMA concept consists of a single wave arriving from a single direction for 
each signal source (i.e., a multipath-free environment). A direction-finding algorithm 
is employed to estimate the direction parameter associated with each arriving cochannel 
25 signal. Under this model, two signals are inseparable if their directions of arrival are 
identical (i.e., if the sources are collinear with the receive array). DPMA by contrast 
operates in a signal environment where multipath is a key feature. DPMA, unlike 
ADMA, is tolerant with regard to angular separation between sources. Even collinear 
sources having zero angular separation at the receiving array are separable because 
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different multipath structures cause the sources to have different generalized steering 
vectors which the CURE algorithms exploit. 

12.0 Application To Two-Way Mobile Wireless Communication Systems: 

5 The CURE cochannel signal separation technology is applicable to 

communication networks composed of two-way communication links in which multiple 
transmissions occur simultaneously on the same frequency. The natural application for 
CURE is to the receiving end of a communication link provided it is practical to have 
an antenna array at the receiving end. For a two-way communication link, this would 

10 mean having a receiving antenna array at both ends of the link. In many situations, 
however, it is practical to have an array at only one end of a communication link. For 
instance, in personal mobile wireless communication networks, it is impractical to have 
an array built into the user's portable handheld units. In such situations, it is possible, 
under certain conditions, to establish and maintain isolation between different 

15 cochannel users by putting arrays at just one end of the communication link. 

CURE cochannel signal separation technology can be applied to cellular 
communication systems in which the earth's surface is partitioned into localized 
regions called 'cells,' as described above with reference to FIG. 29. Examples of 
cellular personal mobile wireless communication systems are the Advanced Mobile 

20 Phone System (AMPS) and Global System Mobile (GSM). (See The Bell System 
Technical Journal, special issue on Advanced Mobile Phone Service, vol. 58, no. 1, 
January 1979.) 

The CURE cochannel system has been described to this point as a 
technology used at the receiving ends of communication links provided the receiving 
25 ends have multi-element antenna arrays. In the case of cellular networks, however, 
economics dictates that arrays be put at base stations only. There are two reasons for 
this: 

• An antenna array is a large and expensive physical asset, best suited to 
installation at fixed base stations where proper maintenance and repair is 
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possible. Mobile units would be larger and more expensive if they were 
required to have antenna arrays built in. 
• A single base station array can serve many users at once. Since each cell 
has more mobile units than base stations, total system cost is lower if arrays 
5 are employed at the base stations only. 

The effect of locating arrays at base stations is to lower the initial 
equipment purchase cost to the subscribers while increasing the infrastructure cost, 
which is spread over all subscribers in the form of monthly service charge. 

Like the application to cellular networks, CURE cochannel signal 
10 separation technology can be applied to satellite-based personal communication 
networks in which a space-based array on a satellite forms spot beams on the surface of 
the earth that define regions similar to the cells formed with terrestrial base stations. 
All communication within a spot beam is between the mobile users and the satellite. 
Communication that bypasses the satellite, between two users in the same spot beam, is 
15 precluded. Examples of satellite-based personal mobile wireless communication 
systems are Iridium, Odyssey, and Global Star. 

There are several reasons and advantages relative to the use of CURE 
cochannel signal separation technology in personal mobile wireless communication 
networks. 

20 • The capacity of a network to accommodate users can be increased by 

employing intra-cell frequency reuse. CURE technology makes this 
possible by means of diversity path multiple access (DPMA) on the reverse 
links or uplinks from mobile user-to-base stations or satellite and by 
transmit beamforming on the forward links or downlinks from base station 

25 or satellite to mobile user. 

• Apart from capacity improvement, CURE provides diversity gain which, 
when used with suitable power control algorithms, can enable the mobile 
users to maintain reliable communication with less average transmitted 
power. 
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• CURE provides general interference immunity not only from other users in 
the network but from arbitrary radiated interference, whether deliberate or 
unintentional. 

5 12.1 Transmit Beamforming: 

The selectivity that enables several users to simultaneously share a 
radio-frequency (RF) channel for transmission can be accomplished by beamforming at 
the transmitters instead of at the receivers. In the case of a cellular network, it is 
possible, by means of transmit beamforming, for forward link transmissions (from base 

10 station to mobile user) to be sent out with directivity patterns that reach the intended 
user while preventing reception at other cochannel users. Two methods can be used to 
accomplish the requisite transmit beamforming function: switched fixed beams and 
adaptive beams. The basic principles of both approaches are known in communication 
engineering. However, proper operation depends on integration with the receive 

15 beamforming function provided by the CURE system. This integration is described 
below. 

In the switched beam approach, a transmit antenna array and a set of 
fixed pre-formed beams is available for transmission. The beams are formed by 
applying signals with appropriate gains and phases to the antennas. The gains and 

20 phases can be created either by a passive beamforming matrix that is inserted into the 
signal path ahead of the antenna array. The outputs of the beamforming matrices are 
then summed in power combiners that drive each array antenna. The preferred 
approach, shown in FIG. 32, eliminates the expense of RF hardware beamformers in 
favor of digital signal processing. In this method, a signal to be transmitted to a user is 

25 input on one of N multiple lines 320 to one of N sets of multipliers 322. Each set of 
multipliers has as other inputs a transmit beamformer weight vector, which is derived 
from a transmit/receive beamformer weight vector computer 324. The latter computer 
receives estimated generalized steering vectors on lines 36 from the CURE system and 
generates receive beamformer weights on lines 48 (see FIG. 4A), and transmit 

30 beamformer weight vectors on lines 326. 
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Thus, in each set of multipliers 322, a signal to be transmitted to a user 
is multiplied by a transmit beamformer weight vector, which is an M-dimensional 
complex weight vector, where M is the number of antenna elements. For each of N 
users, the outputs of the multipliers 322 are summed in a plurality M of summers 328. 
5 That is to say, each summer 328 sums the contributions of multiple user signals 
associated with a particular antenna element. The signal to be radiated by the i* 
antenna of M elements is the sum of N terms, each being a complex weighted version 
of the signal to a different user. An M-channel digital-to-analog converter (DAC) 330 
and linear power amplifier (LP A) 332 is used to drive each antenna. This latter 
10 method does not require expensive analog rf beamforming matrices and power 
combiner hardware, since the multipliers 322 and summers 328 are digital processing 
components, as indicated by the envelope 334. 

In the switched beam approach, the beamforming weight vectors are pre- 
computed and stored in memory. Each weight vector can be used to create a 
15 directional beam that puts transmitted energy in a different direction. The set of all 
such weight vectors provides a family of pencil beams that covers all directions in the 
cell. Only one such beam is selected for transmission on each of the L forward links. 
The method of selection is described below. The method mitigates, but does not 
eliminate, cochannel interference because the energy of a signal unintentionally 
20 radiated to other cochannel users is suppressed to the sidelobe level of the beam, 
assuming the other users do not fall into the main lobe of the beam. For cellular 
systems that use analog frequency modulation (FM) on the forward links like the 
AMPS system in the United States, there is, in addition to sidelobe suppression, the 
signal capture effect of FM discriminators that provides additional suppression of 
25 unwanted cochannel interference. 

A beam is chosen for transmission to a particular user by means of 
logical rules embodied in a beam selection algorithm. The objective is to prevent 
energy from reaching the other cochannel users where it would interfere with the 
intended signals being sent to those users. Consider the following set of assumptions, 
30 reasonable for many wireless communication services that operate at UHF frequencies: 
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• The base station has separate transmit and receive arrays. 

• The transmit and receive arrays are geometrically similar (i.e., have the 
same shape). 

• The transmit and receive arrays have the same size-frequency products (i.e., 
5 the ratio of the transmit-to-receive array sizes equals the ratio of the receive- 

to-transmit frequencies). 

• The transmit and receive arrays are mounted on a common vertical mast. 

• The dominant multipath scatterers are not in the immediate vicinity of the 
arrays, so that the arrays are in the farfield of reradiation from scatterers, 

10 and the elevation or depression angle of arrival is essentially zero at both 

arrays. 

Under these assumptions, the best beam for sending energy to a given 
user is the one whose beamforming vector is most nearly orthogonal to the generalized 
steering vectors of the other cochannel users (the generalized steering vectors being 
15 those derived from reception of the reverse link signals at the base station). 
Orthogonality between two vectors is strictly defined as an inner product of zero. 
However, strict orthogonality is not generally possible. Fortunately, it is often good 
enough to pick the beam whose weight vector has the smallest inner product with the 
reverse link generalized steering vectors of the other cochannel users. This beam will 
20 radiate minimal sidelobe energy to the other users. 

The beam selection criterion for using a fixed switched-beam array can 
be stated precisely: Choose the beam that maximizes the ratio of the inner product of 
the beam vector with the generalized steering vector of the intended user divided by the 
sum of the inner products with the generalized steering vectors of the unintended 
25 cochannel users. 

The method just described uses a fully adaptive array for the reverse 
link receive function, as implemented by the CURE method, together with a switched- 
beam array for the forward link transmit function. The key feature of this approach is 
that antenna arrays are employed only at base stations. 
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A somewhat different approach would be to perform the transmit 
beamforming by using the exact generalized steering vectors as are derived by the 
receive function. This method requires a transmit array that is geometrically similar to 
the receive array as described above (i.e., the transmit and receive arrays have the 
5 same shape but are scaled by the ratio of the receive-to-transmit frequencies). For 
example, in the case of the AMPS analog cellular systems, the transmit and receive 
frequencies are offset by 45 MHz. Because the total system bandwidth is small 
compared to the operating frequencies, the 45 MHz offset can be regarded 
approximately as a 5 percent difference in scale. By using a scaled transmit array, if a 
10 generalized steering vector obtained by CURE on receive is used for transmit, then the 
same array directivity pattern will result. Thus, lobes and nulls will be placed at the 
same angles. Nulls directed to other cochannel users on receive will also be directed at 
the same other users on transmit, thereby enabling the base station to selectively direct 
a signal at a particular desired cochannel user. 
15 In a multipath environment, the desired user and other user signals will 

generally be via diversity paths (i.e., the DPMA concept). In this case, the generalized 
steering vectors derived by CURE on receive cause the receive array (and hence the 
transmit array) to have a complex directivity pattern for each user that sums the 
multipath arrivals of the desired signal with complex weights (gains and phases) that 
20 causes them to add in phase, while simultaneously summing the multipath arrivals of 
each other user cochannel signal with complex weights that causes these signals to sum 
to zero. Thus, other users are rejected by generalized nulls or orthogonality rather 
than by physical nulls at specific angles. The energy transmitted to a particular user 
will be sent in the same direction as the receive multipath components, with the same 
25 phase and gain relationships. Therefore, the signal will reach the intended user with a 
substantial signal level via the diversity path. Simultaneously, the signal will reach the 
other users via multiple paths that will sum to zero provided the mobile users are using 
a simple omnidirectional antenna for both transmit and receive. 

FIG. 33 is block diagram of a transmitter for use in one form of the 
30 CURE system. Some of the components of the transmitter have already been 
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introduced in the discussion of FIG. 32. A transmit weight vector computation or 
beam selection module 340 generates on lines 326 a transmit weight vector for each 
user k. the module 340 generates the transmit weight vector based on either of the two 
approaches discussed above An information signal to be transmitted to user k is 

5 modulated in a modulator 342 and then multiplied by the transmit weight vector for 
user k, in a set of multipliers 328. The portion of the transmitter including the 
modulator 342 and multipliers 322 is referred to as the transmit beamformer 344. Next 
the outputs of the multipliers 322 are summed in a set of M summers 328, each 
summer receiving as inputs an antenna element contribution associated with each of the 

10 users. Thus each summer 322 has N inputs if there are N users. The summers 328 are 
collectively referred to as a signal combiner 346. 

The outputs of the summers 328 are then processed in what is referred 
to as the air interface 348 of the transmitter. The air interface includes a set of complex 
digital-to-analog converters (DACs), each of which produces two outputs, the in-phase 

15 and quadrature components of the complex signals. These complex signal components 
are multiplied by a carrier signal in additional pairs of multipliers More specifically, 
each complex output pair from a complex DAC 330 is multiplied by signals 
proportional to cos co c t and sin w c t, respectively, where w c is the angular carrier 
frequency. The resulting products in each pair are then added in summers 352 and 

20 coupled to one of the linear power amplifiers 332, and from there the signals are 
coupled to an antenna element 110. 

13.0 System For Separating And Recovering Multimode Radio Signals: 

This section describes a method and apparatus for mitigating 
25 polarization effects on propagated radio signals. In the case of dual-polarized radio 
transmissions, the effects of a polarization-changing propagation medium are avoided 
by separating the two received signals without regard to their polarization states. 

This invention relates generally to radio communications and, more 
specifically, to problems that arise, due to natural propagation conditions, when 
30 multiple cochannel signals of practically the same frequency are received at 
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approximately the same time. Propagation conditions may cause may cause unwanted 
polarization mixing of the signals. Separating and recovering the original signals poses 
difficulties in receiver design. 

A related problem is multipath propagation caused by reflections from 
5 atmospheric layers, such as the D-Iayer, E-layer or F-layer. The problem manifests 
itself as frequency selective fading or phase distortion that limits the communication 
capability of high-frequency (HF) signals. As already discussed above in Section 9.0, 
the CURE system handles multipath components advantageously by combining all 
coherent signals arriving over different paths as a result of reflections from buildings in 
10 an urban environment. Multipath propagation effects caused by atmospheric reflections 
are handled in exactly the same manner. 

In some communication systems electromagnetic propagating waves are 
used to carry two independent information signals on different polarizations of the 
same carrier signal. These polarizations need not be orthogonal, but do need to be 
15 linearly independent relative to two orthogonal "basis" polarizations, e.g. vertical and 
horizontal linear polarizations or left-hand circular and right-hand circular polarization. 
A traditional problem is that the polarization of a transmitted signal is changed by the 
propagation medium so that the signal arrives at the receiving antenna with a different 
polarization from the one in which it was transmitted. The polarization change may be 
20 due to reflection from oblique surfaces, refraction, or the phenomenon of Faraday 
rotation. Conventional receivers separate differently polarized signals because each 
receiver has knowledge of the expected polarization states. When the polarization of 
one or both signals is changed during propagation, the conventional receiver is 
incapable of properly separating the two signals. 
25 The present invention separates the received signals without regard to 

their possibly changed polarization states. If only one signal is received with an 
unknown polarization is received at a dual-polarized antenna, the invention can extract 
the signal and determine its polarization state. If two signals are sent on orthogonal 
polarizations, the signal polarizations can be random and not orthogonal at the 
30 receiving site, making reception of either signal subject to cochannel interference from 
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the other signal. CURE processing solves the problem by separating and recovering up 
to two independent signals arriving at the receiving array with differently polarizations, 
provided only that the polarizations are linearly independent (i.e., not identical). The 
key advantage of the invention in this application is that it is "blind" to the polarization 

5 states of the received signals. Prior knowledge of the polarization state is not needed to 
separate and recover the signals. In addition, the CURE approach is fast enough to 
enable the recovery of signals whose polarization is time-varying. 

As shown in FIGS. 34 A and 34B, one type of communication system 
makes use of dual-polarized signals at the same frequency. For example, transmitters 

10 360A and 360B transmit uplink signals A and B to a communication satellite 362, 
which retransmits the signals, with different polarization states, to a dual-polarized 
antenna 364 on the ground at a receiving site. However, an atmospheric layer 366 
causes polarization mixing of the two signals, which arrive at the receiving antenna 
with scrambled polarization states. The received signals are processed by a CURE 

15 processing system 368, which effectively separates out the signals A and B without 
regard to their scrambled polarization states. Because of the CURE processing system 
368 is "blind" to antenna configuration, and to the polarization state of the received 
signals, separation and recovery of signals A and B can be effected even when both 
have their polarization states altered during propagation from the satellite transmitter. 

20 

14.0 Application to Separation of Signals Transmitted Over "Waveguide": 

This section describes a method and apparatus for separating and 
recovering signals transmitted onto a "waveguide." As mentioned earlier, the term 
"waveguide" as used in this specification is intended to include any bounded 
25 transmission medium, such as a waveguide operating at microwave frequencies, an 
optical fiber operating at , a coaxial cable, or even twisted-pair conductors operating at 
lower frequencies. Regardless of the waveguide medium, the signals are received at an 
array of sensor probes installed in the waveguide, and are fed to a cumulant recovery 
(CURE) system that separates and recovers the original signals without regard to how 
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the original propagation modes may have become scrambled as a result of transmission 
along the waveguide. 

Waveguides and optical fibers are widely used for the transmission of 
multiple independent cochannel signals simultaneously, by using a different 

5 propagating mode for each signal. However, due to kinks, bends and surface and 
refractive irregularities in the waveguide or fiber, a phenomenon called mode 
conversion occurs, and the propagated energy is converted from one mode to another 
during propagation along the waveguide or optical fiber medium. Over a long distance 
of propagation, the signals tend to become scrambled across the propagating modes. 

10 A well known approach to conserving bandwidth is to employ different 

propagating modes for different signals of the same frequency, and to rely on the 
different propagating modes to effect separation of the signals as the receiving end of 
the waveguide or optical fiber. Unfortunately, however, mode conversion often occurs, 
especially in long waveguides or fibers, as a result of kinks, bends, and surface and 

15 refractive irregularities of the propagation medium. The modes become scrambled and 
separation at the receiving end becomes difficult. For optical systems, these difficulties 
are somewhat reduced by the use of expensive single-mode fiber. 

FIG. 35 shows, by way of example, a computer network employing an 
optical fiber 370 and having a plurality of computer workstations 372 connected to the 

20 fiber by couplers 104, each of which couples a workstation to the fiber using a 
different propagation mode, but at the same optical frequency. In accordance with the 
invention, a plurality of probes 376 are also coupled to the fiber 370, providing three 
output signal lines for connection to a cumulant recovery (CURE) processing system 
378, which generates separated signals A, B and C at its signal recovery ports. 

25 

15.0 Application to Radio Direction Finding: 

This section describes a method and apparatus for finding accurate 
directions of multiple radio signal sources without the need for a fully calibrated 
antenna array. Signals from the antenna array are processed in a cumulant recovery 
30 (CURE) processing system to recover the signals and obtain estimated steering vectors 
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for the multiple sources. Signals from a subarray of antennas that are calibrated are 
combined with the steering vector estimates to obtain accurate directional locations for 
all of the sources. There need be only as few as two calibrated antenna elements in the 
subarray. 

5 This invention relates generally to direction finding (DF) systems and, 

more particularly, to DF systems using arrays of radio antennas. Traditional super- 
resolution direction finding systems require an array of N+ 1 calibrated antennas and 
receiving channels to resolve N source locations (directions). Maintaining large arrays 
of antennas in calibration adds to the cost of the system. Moreover, traditional DF 

10 systems do not always converge rapidly on the direction solutions. 

FIG. 36 shows a direction finding system in accordance with the 
invention, including an array of antennas 380, only two of which are calibrated, a 
CURE processing system 382 and a copy-aided direction finding system 384. Signals 
are received from multiple sources 386 at different directional locations with respect to 

15 the antenna array 380. As described in detail in the foregoing descriptive sections, the 
CURE processing system 382 separates and recovers the signals from the sources 386 
and outputs the recovered signals from separate output ports, as indicated at 388. A by- 
product of the signal recovery process is a set of steering vector estimates for the 
multiple sources 386. 

20 Assume that the k" 1 port provides the steering vector estimate a k (m) from 

its analysis of the m' h block of data "snapshots," and the steering vector from the 
calibration table for the bearing 0 is denoted as a(0). When an antenna array is 
"calibrated," a calibration table is generated, associating every bearing angle with an 
antenna steering vector. The dimensionality of a(9) is equal to the number of calibrated 

25 sensors, which must be greater than or equal to two. After the steering vectors are 
estimated, a search is done to estimate the directions of arrival for the sources captured 
by the ports. 

The bearing Q k of the source captured by the port k is estimated by the 
maximizer of the DOA spectrum: 
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Some alternative methods to that just described were given by B. Agee 
in "The Copy/DF Approach to Signal Specific Emitter Location," Proc. Twenty-Fifth 
Asilomar Conference on Signals, Systems, and Computers, pp. 994-999, Pacific 

5 Grove, CA, November 1991. Agee concludes that the copy-aided DF method gives 
more accurate DO A estimates than other systems, such as MUSIC (discussed at length 
in the Background of the Invention section), and that these estimates require less 
computation than does MUSIC. An additional advantage is that only two calibrated 
sensors are adequate for azimuth estimation since the search is performed using the 

10 estimated steering vector for one source instead of the signal subspace. In the case of 
multipath propagation, more sources can be resolved by the copy-aided DF approach 
than by MUSIC when spatial smoothing is used. 



16.0 Application to Extending the Dynamic Range of Receiving Systems: 
15 This section describes a method and apparatus for extending the 

effective dynamic range of a radio receiving system by removing the principle products 
of distortion through the use of a cumulant recovery processing system. A received 
signal of interest is separated from the products of distortion, which are independent of 
the signal of interest. The signal is forwarded for further processing and the products 
20 of distortion are discarded, resulting in an extended dynamic range. 

The dynamic range is a measure of the useful output of a receiver in 
relation to noise and other unwanted components. It is limited by the intermodulation 
and distortion products that result from analog and digital nonlinearities. Analog 
nonlinear distortion products or spurs can be generated due to signal overload or 
25 saturation of the first stage, mixer noise, and other sources. Digital systems employ 
analog-to-digital (A/D) converters that produce nonlinear distortion due to uniform 
quantization noise, A/D saturation, non-monotonicity of the A/D characteristic, 
sampler aperture jitter, and other physical effects. Accordingly, there has been an 
ongoing need for significant improvement in the dynamic range of a receiver system. 
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FIG. 37 shows a multichannel receiver 390, receiving signals from 
sources 392 through an antenna array 393 and coupling the input signals to a cumulant 
recovery (CURE) processing system 394. The received signals, after analog processing 
and analog-to-digital conversion, have a spectrum that includes a number of products 

5 of distortion, in the form of nonlinear spurs in the spectrum, as well as lower-level 
quantization noise across the entire spectrum of interest. The effect of CURE 
processing is to separate and recover (or discard) received signals. In this case, the 
CURE processing system provides an output port for the desired signal, and generates 
other outputs corresponding to the principal products of distortion, which may be 

10 discarded. The resulting spectrum after CURE processing exhibits improved effective 
dynamic range, and contains only lower intensity spurs, and low level noise. 
Accordingly, the invention eliminates a number of distortion products in the receiver 
output and provides a desired output signal with fewer and lesser products of 
distortion. 

15 

17.0 Application to High Density Recording: 

This section describes a method and apparatus for separating and 
recovering data recorded on closely spaced tracks on a recording medium. An array of 
sensors senses recorded data from multiple tracks simultaneously, and a cumulant 

20 recovery processing system separates and recovers the data from each of the multiple 
tracks, without crosstalk or mutual interference. Use of the invention permits recording 
of data at much higher densities than is conventional, so that more data can be stored 
on a recording disk without increasing its physical size. 

For space efficiency, magnetic recordings use multiple parallel tracks to 

25 record information. Both rotating disks and linear tape use parallel tracks. Tracks can 
be laid down in the recording medium side-by-side on the surface and on top of one 
another at different vertical depths. On playback, a playback head attempts to sense 
individual tracks without crosstalk or interference from adjacent tracks, but at 
sufficiently high recording densities and small track sizes, crosstalk becomes a 

30 significant problem. Accordingly, designers of such systems are constantly seeking to 
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improve playback head performance and the precision with which the playback head 
can be positioned to read information from each track. The present invention provides 
for increased recording density without crosstalk or mutual interference between 
adjacent tracks. 

5 As shown in FIG. 38, which depicts a recording disk 400 by way of 

example, playback or retrieval of recorded information is effected by means of a 
multisensor array 402, which has individual sensor elements that can sense recorded 
information on more than one track simultaneously. In general, N sensors will permit 
separation of information from N adjacent tracks. In the illustrated form of the 

10 invention, there are three sensors in the array 402 and the array spans across three 
adjacent recording tracks. The signals from the three sensors are processed as 
independent cochannel signals by a cumulant recovery (CURE) processing system 404, 
which generates outputs on three ports, corresponding to the signals on the three tracks 
over which the sensor array is positioned. Depending on the design of the system, 

15 selection from among the three outputs may be simply a matter of choosing the 
strongest signal, which should correspond to the track above which the array is 
centered, or utilizing the information in all three tracks, based on identifying data 
contained on the tracks themselves. Accordingly, the invention represents a significant 
improvement in recording and playback techniques using high-density recording media. 

20 

18.0 Application to Complex Phase Equalization: 

This section describes a method and apparatus for effecting automatic 
phase rotation equalization of a quadrature amplitude modulated (QAM) signal received 
from a transmitter. Because QAM signals are subject to an unknown phase rotation 
25 during propagation, de-rotation or phase rotation equalization is required before the 
received signal can be QAM demodulated. In this invention, received downconverted 
QAM signals are subject to processing in a cumulant recovery (CURE) processing 
system, which recovers the originally transmitted I and Q signals and automatically 
provides phase rotation equalization, without knowledge of the amount of rotation. 
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Thus the invention provides the correct amount of phase compensation automatically, 
even as channel propagation conditions change. 

This invention relates generally to communication systems and, more 
particularly, to phase rotation equalization in communication systems. Many 

5 communication systems use a form of modulation referred to as quadrature amplitude 
modulation (QAM) for transmitting digital data. In QAM, the instantaneous phase and 
amplitude of a carrier signal represents a selected data state. For example, 16-ary 
QAM has sixteen distinct phase-amplitude combinations, which may be represented in 
a "signal constellation" diagram as sixteen points arranged on a square matrix. A 

10 special case of QAM signals is the phase-shift keyed (PSK) signals for which the 
instantaneous phase alone represents a selected state. For example, 16-PSK has sixteen 
distinct phase selections, and can be represented as sixteen equally spaced points on the 
unit circle. 

Transmission of the modulated signal causes an unknown phase rotation 
15 of the signals, and phase rotation correction, or equalization, is required at the receiver 
before the QAM signals can be demodulated. The present invention provides a 
convenient and automatic approach to effecting this phase rotation equalization. FIG. 
39 shows a conventional transmitter, including a QAM modulator 410 and a transmitter 
412. At the point of transmission, the signal constellation diagram is as shown at 414, 
20 with sixteen phase-modulus points arranged in a square matrix. Each point on the 
diagram represents a unique data state. At the receiver site, a receiver and 
downconverter 416 generates I and Q signal components. The signal constellation 
diagram corresponding to these signals is as shown at 418. The constellation has been 
rotated and must be corrected before QAM demodulation can take place. The receiver 
25 site also has a cumulant recovery (CURE) processing system 420 installed between the 
receiver/downconverter 416 and a QAM demodulator 422. As will be further 
explained, CURE processing has the effect of compensating for the phase rotation 
induced during propagation of the signal to the receiver site, as indicated by the phase- 
corrected QAM signal constellation at 424. 
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The in-phase and quadrature components (I and Q) of a digital 
communication signal are independent and identically distributed at the transmitter 
output, as indicated in FIG. 40Aa). If x(t) is the original communication signal (in 
analytic representation) with in-phase component x p {t) and quadrature component x q {t), 
5 respectively, then x p {t) and x q (t) are statistically independent. After transmission, the 
channel distorts the transmitted signal and the receiver recovers it with gain and phase 
ambiguity (ignoring measurement noise), i.e. if y(t) is the output of the receiver, we 
have: 

y(0 = Gexp(/e).x(0. 

10 If y p (t) and y q (t) denote the in-phase and quadrature components of y(t) 

respectively, then we can write: 

y P (0]_ rcos(9) -sin<B)"ir*,(0l 
y q (t)\ G '[sm(Q) cos(9) J [x q (t)\ 

The gain term G is real-valued and affects only the scale of the signal 
constellation, but not the constellation's shape or alignment with the I and Q axes. 
15 Therefore, without loss of generality, we may assume that G= 1 . 

The effect of transmission is to rotate the entire signal constellation by 
the unknown phase angle G, as is shown in FIG. 40B. In order to demodulate the signal 
correctly, the constellation must be "de-rotated" back to its original position prior to 
demodulation. This de-rotation operation must be accomplished by complex phase 
20 equalization or phase correction of the I and Q signals, which compensates for the 
distortion introduced by the communication channel and the lack of phase reference in 
the receiver downconverter's local oscillator. 

The CURE method can be applied to provide a unique solution to the 
problem of complex phase rotation equalization. The signal's center frequency for 
25 downconversion must be known accurately enough so rotation does not occur during a 
processing block. The following two paragraphs help explain how the CURE system 
effects complex phase correction: 

1) y p (f) and y q (t) are not independent but are uncorrelated. The absence 
of statistical independence is evident by inspection of FIG. 40B. Uncorrelatedness is 
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implied by the equation. Because the signals are uncorrelated, second-order statistics 
such as cross-correlation functions provide no information to correct for the rotation of 
the signal constellation. 

2) The rotation correction problem can be considered as a blind signal 

5 separation problem in which there are two sensor signals y p (t) and y q (t), each of which 
is a linear combination of two independent source signals x p {f) and x q (f). This is 
precisely a problem model to which the CURE processing system can be applied. By 
applying the CURE method to the components of the analytic signal, the vector channel 
is phase equalized, the original independent I and Q signals are recovered, and the 

10 received signal constellation is de-rotated. In addition, since y p (t) and y q (t) are 
uncorrelated, the covariance matrix used in the CURE system will be a scaled identity 
matrix, which simplifies the preprocessing required in the CURE system. 

The principal advantage of using the CURE system as an equalization 
technique is that the rotation angle 0 need not be known. The CURE system 

15 compensates for the angle automatically to provide independent output signals. 
Moreover, the equalization process adapts as channel conditions change. 

The CURE system can be used to adjust the complex phase for single- 
dimensional constellations, such as pulse-amplitude modulation (RAM). In this case, 
the scenario can be considered as a two-sensor, single-source, signal enhancement 

20 problem, which can be handled by the CURE processing system. 

19.0 Extension to Wideband Signal Separation: 

The present invention is fundamentally a method for separating and 
recovering narrowband cochannel signals illuminating a sensorarray. However, it is 
25 possible to extend the method to the separation and recovery of wideband signals. This 
is accomplished by: 

1) Partitioning the wideband spectrum into multiple narrowband segments. 

2) Using an array of cochannel processors to perform signal separation in each 
narrowband segment. 
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3) Combining the narrowband results to recover the original wideband source 
waveforms. 

Steps 1 and 2 are straightforward. Step 3, however, is intricate and 
requires a special cumulant test to associate the ports at one frequency segment with the 

5 ports at adjacent frequency segments. Methods to accomplish these steps are described 
below. The overall method is capable of separating and reconstructing wideband 
signals with no special constraints on the signals or their spectra other than that the 
components of the signals in each narrowband segment must be non-Gaussian. A key 
advantage of this method is that the signal spectra are not required to be gap-free (i.e., 

10 have a convex support set). 

19.1 Partitioning Wideband Measurements to Narrowbands: 



decompose the sensor measurements into narrowband components. This decomposition 
15 step is depicted in block 430 of FIG. 41. If r(0 is the array snapshot at time t, then let 
r (tj) denote the measurement component filtered by a bandpass filter centered at 
frequency/. The bandpass filters are designed to satisfy the expression: 



where /,</</„ is the wideband analysis spectrum. With this analysis approach, the 
20 signal model for each band is expressed as 



The following important fact about the cross-cumulants of bandpass filtered signals will 
be exploited in order to associate the ports of different signal separation processors 
operating in different frequency bands: 



To apply the CURE algorithm to separate the signals, it is necessary to 



r(0 =!>,/). 



/=// 



25 



where y^ k (f lx f 2 ) * 0 in general, and 5 kJ is the Kronecker delta function 
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In other words, the cross-cumulant is nonzero for different frequency 
components from the same source and zero for different sources. 

This property is in contrast to the cross-correlation between the 
components of signals at different frequencies which, except for signals that exhibit 
5 second-order cyclostationarity, is generally given by 

^{**^/f)*;^/.)}=c* 2 (/f)8*.i»/ f ./,. 

Here, we see that the components of a given signal at different 
frequency bands are uncorrelated and the components of different signals are 
uncorrelated. 

10 The advantage of the cumulant property noted above is that it provides a 

method (described below) for associating the narrowband parts of a wideband signal 
that is broadly applicable to all signal types regardless of whether a given signal 
exhibits 2nd-order cyclostationarity. 

15 19.2 Signal Separation in Narrowbands: 

Each narrowband component (r(t,f)) is fed to a different CURE signal 
separation processor 432 that separates and recovers the signals that comprise the 
narrowband component. 

Let gk(t,f) be the waveform recovered by the port of the CURE 
20 subsystem that operates in band / processing r(t,f). We shall show a method of 
determining which narrowband port signals are part of a common wideband signal, and 
how to combine these port signals in order to reconstruct and recover the wideband 
signal. 

25 19.3 Combining Narrowbands: 

The problem of combining the recovered narrowband signals to form 
wideband signals is complicated primarily by the fact that the ports for different bands 
capture different sources. The combing step is indicated as block 434 in FIG. 41. In 
general, 
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Consider first the case in which the wideband analysis band is broken 
into two narrow bands f x J 2 , and two processors, each equipped with L signal extraction 
ports to independently process the bands. 
5 Suppose the first port of the processor operating in band /, has captured 

a signal and we wish to find whether some port of a second processor assigned to a 
different band/ 2 captures the same signal. This determination is made by the following 
test. Compute the following quantity for the active ports (indexed by l) of the second 
processor: 

10 - 1 cum(g 1 (f > / I ) f g;(f,/ I ) f a(/ > / a Xa(r,/2)) I" 

We associate a port of the second processor to the first port of the first 
processor if both ports jointly minimize the quantity and if the minimum is below a 
threshold. The threshold is set to limit the number of false association decisions on 
average. For example, if port 3 of the second processor provides a minimum below 
15 threshold, then the waveforms from the two processors would be combined according 
to 

*.(0 =£.(',/.) . 
Conversely, if the maximum is below threshold, then we let 

*.(0=a(f./i) . 

20 In the general case, there are J signal separation processors operating in 

J bands, each having active signal energy on up to L output ports. The method of band 
association in the general case is to first compute the "distance" between all pairs of 
ports by computing the pseudo-metric: 

d(i,k,jJ) - i cum{&(/?y;)j ^ (a) , g/a)/ . )5g ; (,,/.)} |' 

25 for / < i, j <J,mdl<k,l< L, 
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where g k (t,fj) denotes the waveform from the fe* port of the processor in the i* band. 
d(i,k; j,l) is not a true mathematical metric because it does not satisfy two of the three 
required metric properties: d(i,k; j,l) * 0 and the triangle inequality are not satisfied. 
Nevertheless, as a pseudo-metric, it does enable port associations to be found. 

5 The next step is to associate ports two at a time. This is done with a 

clustering algorithm borrowed from the field of statistical pattern recognition. An 
agglomerative hierarchical clustering algorithm is used. Standard algorithms for such 
clustering are described in textbooks (e.g., Richard O. Duda and Peter E. Hart, Pattern 
Classification and Scene Analysis, John Wiley & Sons, 1973, pp. 228-237). This type 

10 of clustering algorithm searches through the inter-port distances to find the two nearest 
ports. If the distance is below a threshold, the ports are "merged" or associated and all 
distances to the two ports that are merged are replaced by distances to the new 
"merged" signal. This process is repeated until only distances greater than the 
threshold remain. Constraints are imposed on the clustering algorithm to prevent the 

15 merging of same-band ports because, if the ports are from the same processor, they 
cannot capture the same signal. 

The distances between same-band ports are used to compute the 
threshold that controls whether ports are sufficiently close to permit them to be 
merged. The threshold is computed by a statistical L-estimator operating on the same- 

20 band distances. The distances are sorted into ascending order, and a particular distance 
is selected based on its rank. This distance is multiplied by a constant to obtain the 
threshold. Both the rank and the constant depend on / and L and are chosen to 
maintain the probability of false port association, F pa , below some small specified level 
(e.g., 0.001). 

25 After the ports are logically merged or associated into clusters, each 

cluster will correspond to exactly one wideband signal. The final step is to recover the 
waveforms of the wideband signals. This is done by adding together the output port 
signals from all the ports merged or associated to each cluster. 
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20.0 Conclusion: 

As described in detail above, the present invention provides a cochannel 
signal processing and separation that has many facets. Implementation of the basic 
cumulant recovery (CURE) processing engine may take the form of any of the 

5 proposed embodiments, including eCURE (as described in Section 3.0). CiCURE 
(Section 4.0) or pipeCURE (Section 5.0), and its capabilities may be further extended 
using a-pCURE or uCURE (Section 6.0), wideband processing (Section 19.0), or 
direct (non-iterative) computation (Section 7.0). 

Applications of a selected form of the CURE processing engine are 

10 numerous, and probably not all have been described here. Of prime importance is the 
application of CURE processing to communication systems (described in Sections 8.0 
through 12.0), and in particular the concept of diversity path multiple access (DPMA, 
described in Section 11.0), which not only permits operation in the presence of 
multipath propagation, but also takes advantage of multiple coherent signals to provide 

15 a diversity gain, and uses a generalized steering vector representative of all the 
multipath components to generate corresponding transmit weight vectors ensuring that 
each user receives intended transmissions, even in the presence of multipath effects. 
Other communication system applications include signal recovery in the presence of 
strong interfering signals (described in Section 10.0), recovery of multimode signals 

20 that have been subject to unwanted mode mixing (Section 13.0), and recovery of signal 
from a bounded waveguide of any type (Section 14.0). Other applications include radio 
direction finding (Section 15.0), extending the dynamic range of receiver systems 
(Section 16.0), high density recording (Section 17.0), and complex phase equalization 
(Section 18.0). 

25 It will be appreciated from the foregoing that the present invention 

represents a significant advance in all of these diverse fields of application. It will also 
be understood that, although a number of different embodiments and applications of the 
invention have been described in detail, various modifications may be made without 
departing from the spirit and scope of the invention. Accordingly, the invention should 

30 not be limited except as by the appended claims. 
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CLAIMS 

We claim: 



1 1. A signal processing system for deriving output quantities of interest 

2 from received cochannel input signals, the system comprising: 

3 a signal receiving system (20), including means (120) for generating a 

4 set of conditioned receiver signals from cochannel signals of any modulation or type 

5 received at a sensor array from multiple sources that can vary in power and location; 

6 an estimated generalized steering vector (EGSV) generator (22), for 

7 computing for each source an EGSV that results in optimization of a utility function 

8 that depends on fourth or higher even-order statistical cumulants derived from the 

9 received signals, the EGSV being indicative of a combination of signals received at the 

10 sensors from a signal source; and 

11 a supplemental computation module (24), for deriving output quantities 

12 of interest from the conditioned receiver signals and the EGSV. 

1 2. A signal processing system as defined in claim 1, wherein: 

2 the EGSV generator (22) uses an iterative technique to generate the 

3 EGSV and includes means for generating successively more accurate EGSVs based on 

4 iterative optimization of the utility function. 

1 3. A signal processing system as defined in claim 2, wherein the means 

2 for generating successively more accurate EGSVs includes: 

3 a linear combiner (26), for repeatedly computing a single channel 

4 combined signal from the conditioned receiver signals and an EGSV; 

5 means (30) for supplying an initial EGSV to the linear combiner, to 

6 produce the initial output of a single channel combined signal; 
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7 an EGSV computation module (22), for computing successive values of 

8 the EGSV from successive values of the single channel combined signal received from 

9 the linear combiner and the conditioned receiver signals; and 

10 means (34) for feeding the successive values of the EGSV back to the 

1 1 linear combiner for successive iteration cycles; and 

12 means (in 22) for terminating iterative operation upon convergence of 

13 the EGSV to a sufficiently accurate value. 

1 4. A signal processing system as defined in claim 2, wherein the means 

2 for generating successively more accurate EGSVs includes: 

3 a cross-cumulant matrix computation module (40), for generating a 

4 matrix of cross-cumulants of all combinations of the conditioned receiver signals; 

5 a structured quadratic form computation module (42), for computing 

6 successive cumulant strength functions derived from successive EGSVs and the cross- 

7 cumulant matrix; 

8 means (30) for supplying an initial EGSV to the structured quadratic 

9 form computation module, to produce the initial output of a cumulant strength function; 

10 an ESGV computation module (22), for generating successive EGSVs 

11 from successive cumulant strength functions received from the structured form 

12 computation module; and 

13 means (34) for feeding the successive values of the EGSV back to the 

14 structured quadratic form computation module for successive iteration cycles; and 

15 means (in 22) for terminating iterative operation upon convergence of 

16 the EGSV to a sufficiently accurate value. 

1 5. A signal processing system as defined in claim 1, wherein the EGSV 

2 generator uses a direct computational technique to generate the EGSV, and includes: 

3 a cross-cumulant matrix computation module (40), for generating a 

4 matrix of cross-cumulants of all combinations of the conditioned receiver signals; and 
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5 an EGSV computation module (22') for computing the EGSV directly 

6 from the cross-cumulant matrix by solving a fourth degree polynomial equation. 

1 6. A signal processing system as defined in any of claims 1-5, wherein: 

2 the means for generating the set of conditioned signals includes an 

3 eigendecomposition module (182, 184) for generating an estimate of the number of 

4 signal sources, a transformation matrix (186) for conditioning the receiver signals, and 

5 an eigenstructure (138) derived from the receiver signals; and 

6 the EGSV generator employs signals output by the eigendecomposition 

7 module to compute EGSVs. 

1 7. A signal processing system as defined in any of claims 1-5, wherein: 

2 the means for generating the set of conditioned signals includes a 

3 covariance matrix computation module (120') and a matrix decomposition module, 

4 (120') for generating a matrix; and 

5 the system further includes a beamformer (124), for generating a 

6 recovered signal from the receiver signals, the EGSV and the matrix obtained from the 

7 matrix decomposition module. 

1 8. A signal processing system as defined in any of claims 1-5, wherein: 

2 the means for generating the set of conditioned signals includes an 

3 eigendecomposition module (182, 184) for generating an estimate of the number of 

4 signal sources, a transformation matrix (186) for conditioning the receiver signals, and 

5 an eigenstructure (138) derived from the receiver signals; 

6 the EGSV generator employs signals output by the eigendecomposition 

7 module to compute EGSVs 

8 the system further comprises a multiple port signal recovery unit (242), 

9 including means (242-3.) for matching current EGSVs with EGSVs from a prior data 

10 block to impose waveform continuity from block to block. 
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1 9. A signal processing system as defined in any of claims 2-4, wherein: 

2 signals are processed in successive blocks of data; and 

3 the initial of EGSVs for each new processing block are computed by a 

4 means FIG. 19) for combining a prior block EGSV and a cumulant vector derived from 

5 the utility function. 

1 10. A signal processing system as defined in claim 9, wherein: 

2 the means for combining takes the sum of the prior block EGSV 

3 multiplied by a first factor, and the cumulant vector multiplied by a second factor, 

4 wherein the first and second factors are selected to provide an initial EGSV that 

5 anticipates and compensates for movement of a signal source. 

1 11. A signal processing system as defined in claim 3, wherein: 

2 the system functions to separate a plurality (P) of received cochannel 

3 signals (27); 

4 there is a plurality (P) of EGSV generators including P EGSV 

5 computation modules {22. k) and P linear combiners (26.*), for generating an equal 

6 plurality (P) of EGSVs associated with P signal sources; and 

7 the supplemental computation module (24A) functions to recover P 

8 separate received signals from the P generalized steering vectors and the conditioned 

9 receiver signals. 

1 12. A signal processing system as defined in claim 11, wherein: 

2 the supplemental computation module includes a recovery beamformer 

3 weight vector computation module (44), for generating from all of the EGSVs a 

4 plurality (P) of receive weight vectors, and a plurality (P) of recovery beamformers 

5 (46), each coupled to receive one of the P receive weight vectors and the conditioned 

6 receiver signals, for generating a plurality (P) of recovered signals. 
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1 13. A signal processing system as defined in claim 4, wherein: 

2 the system functions to separate a plurality (P) of received cochannel 

3 signals; 

4 there is a plurality (P) of EGSV generators, including P EGSV 

5 computation modules (22. k) and P structured quadratic form computation modules 

6 (42.&), for generating an equal plurality (P) of EGSVs associated with P signal 

7 sources; and 

8 the supplemental computation module (24A) functions to recover P 

9 separate received signals from the P generalized steering vectors and the conditioned 
10 receiver signals. 

1 14. A signal processing system as defined in claim 13, wherein: 

2 the supplemental computation module (24A) includes a recovery 



3 beamformer weight vector computation module (44), for generating from all of the 

4 EGSVs a plurality (P) of receive weight vectors, and a plurality (P) of recovery 

5 beamformers (46), each coupled to receive one of the P receive weight vectors and the 

6 conditioned receiver signals, for generating a plurality (P) of recovered signals. 



1 15. A signal processing system as defined in claim 5, wherein: 

2 the system functions to separate a two received cochannel signals; 

3 the ESGV computation module (22') generates two EGSVs from the 

4 cross-cumulant matrix data; and 

5 the supplemental computation module (24A) functions to recover two 

6 separate received signals from the two generalized steering vectors and the conditioned 

7 receiver signals. 

1 16. A signal processing system as defined in claim 15, wherein: 

2 the supplemental computation module (24A) includes a recovery 

3 beamformer weight vector computation module (44), for generating from both of the 

4 EGSVs two receive weight vectors, and two recovery beamformers (46), each coupled 
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5 to receive one of the receive weight vectors and the conditioned receiver signals, for 

6 generating two recovered signals. 



1 17. A signal processing system as defined in any of claims 1-5, wherein: 

2 the system functions to derive a direction of arrival (DO A) of a received 

3 signal; 

4 the supplemental computation module includes a memory (50) for 

5 storing sensor array calibration data, and means (24B) for deriving the DO A of a 

6 received signal from its associated generalized steering vector and the stored sensor 

7 array manifold data. 

1 18. A signal processing system as defined in claim 17, wherein: 

2 the sensor array manifold data (50) includes a table associating multiple 

3 DO A values with corresponding steering vectors; and 

4 the means (24B) for deriving the DOA includes means (52) for 

5 performing a reverse table lookup function to obtain an approximated DOA value from 

6 a steering vector supplied by the generalized steering vector generator. 

1 19. A signal processing system as defined in claim 18, wherein: 

2 the means (24B) for deriving the DOA further includes means (54) for 

3 interpolating between two DOA values to obtain a more accurate result. 

1 20. A signal processing system as defined in any of claims 1-5, wherein 

2 the supplemental computation module (24) includes: 

3 a signal recovery module (24A) for generating received signal 

4 beamformer weights from the conditioned receiver signals and the EGSV; and for 

5 recovering the received signal therefrom; and . 

6 a transmitter (56), for generating transmit signal beamformer weights 

7 from the received signal beamformer weights, and for transmitting signals containing 

8 information in a direction determined by the transmit signal beamformer weights. 
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1 21. A signal processing system as defined in claims 12 or 14, wherein 

2 the supplemental computation module (24 A) further includes: 

3 a transmit weight vector computation module (340), for generating P 

4 transmit beamforming weight vectors from receive weight vectors generated by the 

5 recovery beamformer weight vector computation module; and 

6 P linear combiners (328), for combining each of the P information 

7 signals to be transmitted with its associated transmit weight vector, to obtain a 

8 weighted transmit beam for each of the information signals to be transmitted, and then 

9 combining corresponding components of the weighted transmit beams, for coupling to 

10 a transmit array (110). 



1 22. A signal processing system as defined in any of claims 11-16, 

2 wherein: 

3 the signal receiving system includes a plurality of waveguide sensors 

4 (64) for receiving signals transmitted onto a waveguide (62) in different modes, 

5 wherein the modes are subject to scrambling in the waveguide; and 

6 the supplemental computation module (24) separates and recovers the 

7 signals and mitigates the effect of mode mixing in the waveguide. 

1 23. A signal processing system as defined in claim 22, wherein the 

2 waveguide is a microwave waveguide. 

1 24. A signal processing system as defined in claim 22, wherein the 

2 waveguide is an optical fiber. 

1 25. A signal processing system as defined in claim 22, wherein the 

2 waveguide is a coaxial cable. 
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1 26. A signal processing system as defined in claim 22, wherein the 

2 waveguide includes at least one twisted pair of conductors. 

1 27. A signal processing system as defined in any of claims 11-16, 

2 wherein: 

3 the signals received by the signal receiving system are in-phase and 

4 quadrature components of a two-dimensional communication signal (418), which has 

5 been subject to phase rotation during propagation; and 

6 the recovered signals generated automatically from the supplemental 

7 computation module are in-phase and quadrature components of a two-dimensional 

8 communication signal (424) that has been corrected for phase rotation, wherein the 

9 system functions as a complex phase equalizer. 

1 28. A signal processing system as defined in any of claims 1-5, wherein: 

2 the signals received by the signal receiving system have been subject to 

3 distortion by analog processing and analog-to-digital conversion in a radio receiving 

4 system (390); and 

5 the output quantities (from 394) include a recovered signal having 

6 significantly less distortion than the received signals, whereby the receiving system has 

7 improved dynamic range as a result of the use of the signal processing system. 

1 29. A signal processing system as defined in any of claims 11-16, 

2 wherein: 

3 the signals received by the signal receiving system (280) include signals 

4 from a relatively weak desired source (286) and much stronger signals from at least 

5 one interfering source (284); 

6 wherein the recovered and separated signals include those from the 

7 relatively weak desired source (286), free of interference, and those from the stronger 

8 interfering source (284), which can be discarded. 
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1 30. A method for processing cochannel signals received at a sensor 

2 array, the method comprising the steps of: 

3 conditioning a set of signals received at a sensor array from multiple 

4 sources that can vary in power and location; 

5 generating for each source an estimated generalized steering vector 

6 (EGSV) that results in optimization of a utility function that depends on fourth or 

7 higher even-order statistical cumulants derived from the received signals, the EGSV 

8 being indicative of a combination of signals received at the sensors from a signal 

9 source; and 

10 performing supplemental computation to derive output quantities of 

1 1 interest from the conditioned receiver signals and the EGSVs. 

1 31. A method as defined in claim 30, wherein: 

2 the step of generating an EGSV includes providing an initial EGSV and 

3 then iteratively generating successive EGSVs until an acceptable convergence is 

4 attained. 

1 32. A method as defined in claim 31, wherein generating an EGSV 

2 includes: 

3 computing in a linear combiner successive values of a single channel 

4 combined signal derived from an input EGSV and the received signals; 

5 supplying an initial EGSV to the linear combiner; 

6 computing successive EGSVs from the received signals and the 

7 successive values of the single channel combined signal; 

8 feeding the successive EGSVs back to the linear combiner for further 

9 iteration; and 

10 terminating further iteration when the EGSV has satisfactorily 

1 1 converged. 
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1 33. A method as defined in claim 31, wherein generating an EGSV 

2 includes: 

3 computing a matrix of cross-cumulants of the received signals; 

4 computing in a structured quadratic form computation module successive 

5 values of a cumulant strength function derived from an input EGSV and the cross- 

6 cumulants of the received signals; 

7 supplying an initial EGSV to the structured quadratic form computation 

8 module; 

9 computing successive EGSVs from the successive values of the cumulant 

10 strength; 

11 feeding the successive EGSVs back to the structured quadratic form 

12 computation module for further iteration; and 

13 terminating further iteration when the EGSV has satisfactorily 

14 converged. 

1 34. A method as defined in claim 30, wherein generating an EGSV 

2 includes: 

3 generating a matrix of cross-cumulants of all combinations of the 

4 received signals; and 

5 computing the EGSV directly from the cross-cumulants by solving a 

6 fourth degree polynomial equation. 

1 35. A method as defined in any of claims 30-34, wherein: 

2 conditioning the received signals includes generating by eigendecom- 

3 position an estimate of the number of signal sources, a transformation matrix for 

4 conditioning the receiver signals, and an eigenstructure derived from the receiver 

5 signals; and 

6 the step of generating EGSVs employs signals generated in the foregoing 

7 step of generating by eigendecomposition. 
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1 36. A method as defined in any of claims 30-34, wherein: 

2 conditioning the received signals includes generating a covariance matrix 

3 and generating therefrom another matrix; and 

4 the method further comprises beamforming to generate a recovered 

5 signal from the receiver signals, the EGSV and the other matrix obtained from the 

6 covariance matrix. 

1 37. A method as defined in any of claims 30-34, wherein: 

2 conditioning the received signals includes generating by eigendecom- 

3 position an estimate of the number of signal sources, a transformation matrix for 

4 conditioning the receiver signals, and an eigenstructure derived from the receiver 

5 signals; 

6 the step of generating EGSVs employs signals generated in the foregoing 

7 step of generating by eigendecomposition 

8 the method further comprises the step of matching current EGSVs with 

9 EGSVs from a prior data block to impose waveform continuity from block to block. 

1 38. A method as defined in any of claims 31-33, wherein: 

2 signals are processed in successive blocks of data; and 

3 the method further comprises a step of computing an initial EGSV for 

4 each new processing block by combining a prior block EGSV and a cumulant vector 

5 derived from the utility function. 

1 39. A method as defined in claim 38, wherein: 

2 the combining step includes taking the sum of the prior block EGSV 

3 multiplied by a first factor, and the cumulant vector multiplied by a second factor, 

4 wherein the first and second factors are selected to provide an initial EGSV that 

5 anticipates and compensates for movement of a signal source. 
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1 40. A method as defined in claim 32, wherein: 

2 the method separates a plurality (P) of received cochannel signals; 

3 the step of generating an EGSV is performed in a plurality (P) of EGSV 

4 generators, including P EGSV computation modules and P linear combiners, for 

5 generating an equal plurality (P) of EGSVs associated with P signal sources; and 

6 the step of performing supplemental computation includes recovering P 

7 separate received signals from the P generalized steering vectors and the conditioned 

8 receiver signals. 

1 41. A method as defined in claim 40, wherein: 

2 the step of performing supplemental computation further includes 

3 generating, in a recovery beamformer weight vector computation module, from all of 

4 the EGSVs a plurality (P) of receive weight vectors, and generating a plurality (P) of 

5 recovered signals in a plurality (P) of recovery beamformers, each coupled to receive 

6 one of the P receive weight vectors and the conditioned receiver signals. 



1 42. A method as defined in claim 33, wherein: 

2 the system functions to separate a plurality (P) of received cochannel 

3 signals; 

4 the step of generating EGSVs includes generating a plurality (P) of 

5 EGSVs associated with P signal sources; and 

6 the step of performing supplemental computation includes recovering P 

7 separate received signals from the P generalized steering vectors and the conditioned 

8 receiver signals. 

1 43. A method as defined in claim 42, wherein: 

2 the step of performing supplemental computation further includes 

3 generating from of the EGSVs, in a recovery beamformer weight vector computation 

4 module, a plurality (P) of receive weight vectors, and generating a plurality (P) of 
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5 recovered signals in a plurality (P) of recovery beamformers, each coupled to receive 

6 one of the P receive weight vectors and the conditioned receiver signals. 



1 44. A method as defined in claim 34, wherein: 

2 the system functions to separate two received cochannel signals; 

3 the step of generating EGSVs generates two EGSVs from the cross- 

4 cumulant matrix data; and 

5 the step of performing supplemental computation includes recovering 

6 two separate received signals from the two generalized steering vectors and the 

7 conditioned receiver signals. 

1 45. A method as defined in claim 44, wherein: 

2 the step of performing supplemental computation includes generating 

3 from both of the EGSVs two weight vectors, and generating two recovered signals in 

4 two recovery beamformers, each coupled to receive one of the weight vectors and the 

5 conditioned receiver signals. 

1 46. A method as defined in any of claims 30-34, wherein: 

2 the method functions to derive a direction of arrival (DOA) of a received 

3 signal; 

4 the step of performing supplemental computation module storing sensor 

5 array manifold data in a memory, deriving the DOA of a received signal from its 

6 associated generalized steering vector and the stored sensor array manifold data. 

1 47. A method as defined in claim 46, wherein: 

2 the sensor array manifold data includes a table associating multiple DOA 

3 values with corresponding steering vectors; and 

4 the step of deriving the DOA includes performing a reverse table lookup 

5 function to obtain an approximated DOA value from a steering vector supplied by the 

6 generalized steering vector generator. 
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1 48. A method as defined in claim 47, wherein: 

2 the step of deriving the DOA further includes interpolating between two 

3 DOA values to obtain a more accurate result. 

1 49. A method as defined in any of claims 30-34, wherein the step of 

2 performing supplemental computation includes: 

3 generating received signal beamformer weights from the conditioned 

4 receiver signals and the EGSV; 

5 recovering the received signal therefrom; 

6 generating transmit signal beamformer weights from the received signal 

7 beamformer weights; and 

8 transmitting signals containing information in a direction determined by 

9 the transmit signal beamformer weights. 

1 50. A method as defined in claim 41 or 43, wherein the step of 

2 performing supplemental computation further includes: 

3 generating P transmit beamforming weight vectors from receive weight 

4 vectors generated by the recovery beamformer weight vector computation module; and 

5 P linear combiners, for combining each of the P information signals to 

6 be transmitted with its associated transmit weight vector, to obtain a weighted transmit 

7 beam for each of the information signals to be transmitted, and then combining 

8 corresponding components of the weighted transmit beams, for coupling to a transmit 

9 array. 

1 51. A method as defined in any of claims 40-45, wherein: 

2 the method further comprises receiving signals from a plurality of 

3 waveguide sensors positioned to detect signals transmitted onto a waveguide in 

4 different modes, wherein the modes are subject to scrambling in the waveguide; and 
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5 the step of performing supplemental computation includes separating and 

6 recovering the signals, while mitigating the effect of mode mixing in the waveguide. 

1 52. A method as defined in claim 51, wherein the waveguide is a 

2 microwave waveguide. 

1 53. A method as defined in claim 51, wherein the waveguide is an 

2 optical fiber. 

1 54. A method as defined in claim 51, wherein the waveguide is a coaxial 

2 cable. 

1 55. A method as defined in claim 51, wherein the waveguide includes at 

2 least one twisted pair of conductors. 

1 56. A method as defined in any of claims 40-45, wherein: 

2 the signals received by the signal receiving system are in-phase and 

3 quadrature components of two-dimensional communication signal, which has been 

4 subject to phase rotation during propagation; and 

5 the step of recovering signals automatically generating in-phase and 

6 quadrature components of a two-dimensional communication signal that has been 

7 corrected for phase rotation, wherein the method functions as a complex phase 

8 equalizer. 

1 57. A method as defined in any of claims 30-34, wherein: 

2 the received signals have been subject to distortion by analog processing 

3 and analog-to-digital conversion in a radio receiving system; and 

4 the output quantities include a recovered signal having significantly less 

5 distortion than the received signals, whereby the receiving system has improved 

6 dynamic range as a result of the use of the signal processing method. 
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1 58. A method as defined in any of claims 40-45, wherein: 

2 the received signals include signals from a relatively weak desired 

3 source and much stronger signals from at least one interfering source; 

4 wherein the step of recovering the signals includes recovering a signal 

5 from the relatively weak desired source, free of interference, and discarding signals 

6 from the stronger interfering source. 

1 59. A method for recovery and separation of multiple cochannel signals 

2 of any modulation or type received at an array of sensors, the method comprising the 

3 steps of: 

4 receiving a plurality of cochannel signals from separate signal sources at 

5 an array of sensors; 

6 preprocessing the received signals to provide preprocessed signals; 

7 coupling the preprocessed signals to a plurality of signal extraction 

8 ports, which may be in an active state or an inactive state; 

9 in association with each signal extraction port in the active state, 

10 generating an estimated steering vector and a recovered signal corresponding to one of 

1 1 the signal sources, without regard for manifold data of the sensor array; 

12 orthogonalizing the estimated steering vectors to ensure that each signal 

13 extraction port generates a recovered signal for a separate signal source; and 

14 controlling the steps of orthogonalizing and generating recovered signals 

15 to ensure an orderly association of signal sources with signal extraction ports. 

1 60. A method as defined in claim 59, wherein the step of preprocessing 

2 includes: 

3 estimating the number of signal sources of which the signals are being 

4 received at the sensor array; and 

5 transforming the received signals, which have a dimensionality based on 

6 the number sensors, to preprocessed signals, which have a dimensionality based on the 

7 estimated number of signal sources. 
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1 61. A method as defined in claim 60, wherein the step of preprocessing 

2 further includes: 

3 performing an eigendecomposition of the received signals, to produce 

4 signal subspace and noise subspace eigenvalues and eigenvectors, and noise subspace 

5 eigenvalues and eigenvectors; and 

6 computing a transformation matrix from eigenvalues and eigenvectors, 

7 for use in the transforming step. 

1 62. A method as defined in claim 60, wherein the step of generating an 

2 estimated recovered signal in each active signal recovery port includes: 

3 computing an even-order cumulant vector of fourth or higher order from 

4 the preprocessed signals and auxiliary signals related to the estimated recovered 

5 signals; and 

6 using the even-order cumulant vector to compute an estimated recovered 

7 signal, in an iterative process that rapidly converges on a solution for the recovered 

8 signal. 

1 63. A method as defined in claim 61, wherein the step of generating an 

2 estimated recovered signal includes: 

3 initially selecting a random vector to serve as an initial steering vector 

4 a,; 

5 computing a weight value \ k from the steering vector a k , by using the 

6 transformation matrix computed in the preprocessing step, wherein the weight vector 

7 has a dimensionality based on the estimated number of sources P e and the weight value 

8 has a dimensionality based on the number sensors in the array; 

9 computing an estimate of the recovered signal g t (t) from the value \ k and 

10 the preprocessed signal y(t); 

11 computing an auxiliary signal u*(t) from the value \ k and the 

12 preprocessed input signal y(t); 

13 computing a fourth-order cumulant vector from the preprocessed 

14 signals y(t) and the auxiliary signal \ k ; 
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15 orthogonalizing the cumulant vector b* in the orthogonalizer, to produce 

16 an orthogonalized cumulant vector d k ; 

17 deriving an updated steering vector a k from the orthogonalized cumulant 

18 vector d k ; and 

19 repeating the steps of computing the value \ k , computing an estimate of 

20 the recovered signal, computing an auxiliary signal u t (t), computing a fourth-order 

21 cumulant, orthogonalizing, and deriving an updated steering vector, until the recovered 

22 signal converges to an acceptably accurate solution. 

1 64. A method as defined in claim 63, wherein the step of generating a 

2 recovered signal further includes: 

3 calculating a capture strength c k for the each active port. 

1 65. A method as defined in claim 63, and further comprising the step of: 

2 demodulating each of the recovered signals from the signal extraction 

3 ports. 

1 66. A method as defined in claim 63, and further comprising the step of: 

2 generating direction finding data, by converting the steering vector from 

3 each active signal extraction port to a corresponding angular position in three- 

4 dimensional space. 

1 67. A method as defined in claim 63, wherein the step of computing a 

2 fourth-order cumulant vector uses as input variables the auxiliary signal \ k , two 

3 instances of the complex conjugate of the auxiliary signal u t *(t) and the preprocessed 

4 signals y(t). 

1 68. A method as defined in claim 64, wherein the controlling step 

2 includes: 

3 detecting changes in the number of signal sources; and, if the number of 

4 signal sources is changed; 
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5 identifying which signal extraction port was processing a lost source; 

6 and 

7 identifying which signal extraction port will process a new source. 

1 69. A receiver/transmitter system capable of receiving cochannel signals 

2 simultaneously from multiple remote units (310) and transmitting cochannel signals to 

3 the remote units simultaneously, the system comprising: 

4 a signal receiving system (20), including means (120) for generating 

5 from signals received at a receive sensor array (110) a set of conditioned receiver 

6 signals; 

7 a plurality of estimated generalized steering vector (EGSV) generators 

8 (22), for computing for each transmitting remote unit an EGSV that results in 

9 optimization of a utility function that depends on fourth or higher even-order statistical 

10 cumulants derived from the received signals, each EGSV being indicative of a 

1 1 combination of signals received at the sensors from the remote unit; 

12 a recovery beamformer weight vector computation module (44), for 

13 generating from all of the EGSVs a plurality of receive beamforming weight vectors; 

14 a plurality of recovery beamformers (46), each coupled to receive one of 

15 the receive beamforming weight vectors and the conditioned receiver signals, for 

16 generating a plurality of recovered signals; 

17 a transmit weight vector computation module (340), for generating 

18 transmit beamforming weight vectors from the receive beamforming weight vectors 

19 generated by the recovery beamformer weight vector computation module; and 

20 a plurality of linear combiners (328), for combining each information 

21 signal to be transmitted with an associated transmit weight vector, to obtain a weighted 

22 transmit beam for each of the information signals to be transmitted, and then 

23 combining corresponding components of the weighted transmit beams, for coupling to 

24 a transmit array. 

l 70. A receiver/transmitter system as defined in claim 69, wherein: 
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2 signals received from at least one particular remote unit are propagated 

3 over multiple paths to the receive sensor array; 

4 the ESGV associated with the signal received over multiple paths is 

5 representative of a composite of all coherent components of the signal arriving over the 

6 multiple paths, wherein multipath components of the same signal are automatically and 

7 dynamically combined but non-coherent cochannel signals are separated; and 

8 the transmit weight vector used to transmit signals back to the particular 

9 remote unit results in transmit array directivity pattern that achieves transmission over 

10 generally the same multiple paths traversed by the received signals, using a weighted 

1 1 combination of the multiple paths; 

12 whereby the receiver/transmitter system achieves diversity gain by 

13 virtue of its combination of multipath components. 

1 71. A receiver/transmitter system as defined in claim 69, wherein the 

2 transmit weight vector computation module (340) includes: 

3 means for selecting from a plurality of fixed pre-formed transmit weight 

4 vectors, based on the receive beamforming weight vectors. 

1 72. A receiver/transmitter system as defined in claim 69, wherein the 

2 transmit weight vector computation module (340) includes: 

3 means for generating transmit weight vectors adaptively to reflect as 

4 accurately as possible the characteristics of the receive beamforming weight vectors, 

5 whereby signals are transmitted to the respective remote units with minimum 

6 interference because a transmit weight vector associated with a particular remote unit is 

7 selected to be practically orthogonal to all of the estimated generalized steering vectors 

8 associated with transmissions to and from the other remote units. 



1 73. A receiver/transmitter system as defined in claim 72, wherein: 

2 the system includes receive and transmit sensor arrays that are identical 

3 in shape but are scaled in dimension in the same ratio as transmit and receive 

4 frequencies, respectively. 
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1 74. A method for using a receiver/transmitter system capable of 

2 receiving cochannel signals simultaneously from multiple remote units and transmitting 

3 cochannel signals to the remote units simultaneously, the method comprising the steps 

4 of: 

5 receiving signals from a receive sensor array; 

6 generating from the received signals a set of conditioned receiver 

7 signals; 

8 computing for each transmitting remote unit an estimated generalized 

9 steering vector that results in optimization of a utility function that depends on fourth 

10 or higher even-order statistical cumulants derived from the received signals, the 

11 estimated generalized steering vector being indicative of a combination of signals 

12 received at the sensors from the remote unit; 

13 generating from all of the generalized steering vectors a plurality of 

14 receive beamforming weight vectors; 

15 generating from the receive beamforming weight vectors and the 

16 conditioned receiver signals a plurality of recovered signals corresponding to the 

17 signals received from the respective remote units; 

18 generating transmit beamforming weight vectors from the receive 

19 beamforming weight vectors; 

20 combining each information signal to be transmitted with an associated 

21 transmit weight vector, to obtain a weighted transmit beam for each of the information 

22 signals to be transmitted; and 

23 combining corresponding components of the weighted transmit beams, 

24 for coupling to a transmit array. 

1 75. A method as defined in claim 74, wherein: 

2 signals received from at least one particular remote unit are propagated 

3 over multiple paths to the receive sensor array; 

4 the estimated generalized steering vector associated with the signal 

5 received over multiple paths is representative of a composite of all coherent 
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6 components of the signal arriving over the multiple paths, wherein multipath 

7 components of the same signal are automatically and dynamically combined but non- 

8 coherent cochannel signals are separated; and 

9 the transmit weight vector used to transmit signals back to the particular 

10 remote unit results in transmit array directivity pattern that achieves transmission over 

11 generally the same multiple paths traversed by the received signals, using a weighted 

12 combination of the multiple paths; 

13 whereby the receiver/transmitter system achieves diversity gain by 

14 virtue of its combination of multipath components. 

1 76. A method defined in claim 74, wherein the step of generating 

2 transmit beamforming weight vectors includes: 

3 selecting from a plurality of fixed pre-formed transmit weight vectors, 

4 based on the receive beamforming weight vectors. 

1 77. A method as defined in claim 74, wherein the step of generating 

2 transmit beamforming weight vectors includes: 

3 generating transmit weight vectors adaptively to reflect as accurately as 

4 possible the characteristics of the receive beamforming weight vectors, whereby signals 

5 are transmitted to the respective remote units with minimum interference because a 

6 transmit weight vector associated with a particular remote unit is selected to be 

7 practically orthogonal to all of the generalized steering vectors associated with 

8 transmissions to and from the other remote units. 



1 78. A method as defined in claim 77, and further comprising: 

2 selecting receive and transmit sensor arrays that are identical in shape 

3 but are scaled in dimension in the same ratio as transmit and receive frequencies. 

1 79. A two-way communication system using cochannel signals and 

2 diversity path multiple access (DPMA) for transmission in both directions, the system 

3 comprising: 
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4 at least one receiver/transmitter base station (302) for communicating 

5 with a plurality of mobile devices (310) having omnidirectional antennas for 

6 transmitting uplink signals at an assigned frequency and receiving downlink signals at 

7 another assigned frequency, wherein the receiver/transmitter base station includes 

8 a receive antenna array (110), 

9 a plurality of estimated generalized steering vector (EGSV) 

10 generators (22), for computing for each mobile device an EGSV that results in 

11 optimization of a utility function that depends on fourth or higher even-order 

12 statistical cumulants derived from the received signals, the EGSV being 

13 indicative of a combination of uplink signals received at the receive antenna 

14 array from the mobile device over possible multiple paths, 

15 receiver processing means (24 A) for generating from the EGSVs 

16 a recovered signal corresponding to each uplink signal from a mobile device, 

17 and a receive beamforming weight vector corresponding to the uplink signal, 

18 a transmitter (56), including means (340) for generating from 

19 each receive beamforming weight vector a corresponding transmit beamforming 

20 weight vector, and a modulator (342) for modulating a downlink transmission 

21 signal with a desired information signal, 

22 a transmit antenna array (110) coupled to the transmitter and 

23 having a similar geometrical shape as the receive antenna array, wherein 

24 downlink transmission signals intended for a particular mobile device are 

25 propagated along generally the same multiple paths as the received uplink 

26 signals from the same mobile device; 

27 wherein coherent uplink signals received over multiple paths from the 

28 same mobile device are automatically combined, providing a diversity gain effect that 

29 allows weaker transmissions to be detected, and downlink signals transmitted over the 

30 same multiple paths also benefit from the diversity gain effect and provide a stronger 

31 downlink signal to the mobile device. 
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1 80. A two-way communication system as defined in claim 79, wherein 

2 the receiver processing means includes: 

3 a recovery beamformer weight vector computation module (44), for 

4 generating from all of the EGSVs the plurality of receive beamforming weight vectors; 

5 and 

6 a plurality of recovery beamformers (46), each coupled to receive one of 

7 the receive beamforming weight vectors and conditioned receiver signals, for 

8 generating the plurality of recovered signals. 

1 81. A two-way communication system as defined in claim 80, wherein 

2 the transmitter includes: 

3 a transmit weight vector computation module (340), for generating 

4 transmit beamforming weight vectors from the receive beamforming weight vectors 

5 generated by the recovery beamformer weight vector computation module; and 

6 a plurality of linear combiners (328), for combining each information 

7 signal to be transmitted with an associated transmit weight vector, to obtain a weighted 

8 transmit beam for each of the information signals to be transmitted, and then 

9 combining corresponding components of the weighted transmit beams, for coupling to 

10 the transmit antenna array. 



1 82. A two-way communication system as defined in claim 79,. wherein: 

2 the uplink and downlink transmission frequencies are offset from each 

3 other to avoid interference between mobile devices; and 

4 the transmit antenna array has dimensions scaled with respect to those of 

5 the receive antenna array in the inverse ratio of the uplink and downlink transmission 

6 frequencies. 

1 83. A two-way communication system as defined in claim 81, wherein 

2 the transmit weight vector computation module (340) includes: 
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3 means for selecting from a plurality of fixed pre-formed transmit weight 

4 vectors, based on the receive beamforming weight vectors. 

1 84. A two-way communication system as defined in claim 81,. wherein 

2 the transmit weight vector computation module (340) includes: 

3 means for generating transmit weight vectors adaptively to reflect as 

4 accurately as possible the characteristics of the receive beamforming weight vectors, 

5 whereby downlink signals are transmitted to the respective mobile devices with 

6 minimum interference because a transmit weight vector associated with a particular 

7 mobile device is selected to be practically orthogonal to all of the generalized steering 

8 vectors associated with transmissions to and from the other mobile devices. 



1 85. A method for processing received radio signals that are subject to 

2 unwanted change during propagation, the method comprising the steps of: 

3 transmitting radio signals through the atmosphere; 

4 subjecting the radio signals to modification as a result of conditions 

5 prevailing during propagation from a transmitter to a receiver array; 

6 receiving multiple cochannel radio signals at the antenna array; and 

7 processing the received signals to eliminate the effects of modification of 

8 the signals during propagation, wherein the processing step includes cumulant-based 

9 signal recovery without regard for the geometrical properties of the antenna array. 

1 86. A method as defined in claim 85, wherein: 

2 the step of transmitting includes transmitting two different information 

3 signals having two different polarization states; 

4 the step of subjecting the radio signals to modification includes 

5 subjecting at least one of the transmitted signals to a change of its polarization state; 

6 the step of processing the received signals includes separating and 

7 recovering the two information signals without regard to their polarization states. 
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1 87. A method of separating signals transmitted over a waveguide using 

2 different propagation modes in overlapping frequency bands, the method comprising 

3 the steps of: 

4 generating multiple signals in overlapping frequency bands, modulated 

5 by respective information signals using modulation schemes that may be the same for 

6 all of the multiple signals; 

7 transmitting the multiple modulated signals onto an electromagnetic 

8 waveguide, each signal being transmitted in a different propagation mode; 

9 receiving the signals at an array of probes installed in an operative 

10 relationship to the waveguide; and 

11 separating the received signals using a recovery system based on 

12 cumulants of the fourth or higher even order. 

1 88. Communication apparatus for transmitting and receiving signals over 

2 a waveguide using different propagation modes in spectrally-overlapping frequency 

3 bands, the apparatus comprising: 

4 a waveguide (370) serving as a signal transmission medium; 

5 a plurality of signal couplers (374) for injecting modulated signals onto 

6 the waveguide in different electromagnetic propagation modes that are spectrally- 

7 overlapping; 

8 a plurality of signal probes (376) forming a probe array at one or more 

9 places in the waveguide separated from the signal couplers, such that the original 

10 propagation modes are subject to scrambling and distortion as a result of physical 

1 1 irregularities in the transmission medium; and 

12 a recovery system (378) coupled to the signal probes, to effect recovery 

13 and separation of the signals received at the signal probes, using cumulant 

14 computations based on cumulants of the fourth or higher even order. 

1 89. Communication apparatus as defined in claim 88, wherein: 
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2 the waveguide (370) is an optical fiber; and 

3 signals are propagated over the waveguide using different frequency 

4 bands of light (wavelength division multiplexing). 

1 90. For use in a communication network having multiple users and 

2 limited bandwidth, a method for increasing the capacity of the communication system, 

3 comprising the steps of: 

4 allocating up to N users the same bandwidth sharing parameter, such 

5 that the up to N users share the same frequency band at the same time; 

6 receiving signals from up to TV users at an M-element antenna array; and 

7 processing the received signals using a cumulant-based signal recovery 

8 system, to separate and recover the signals transmitted by the respective users. 

1 91. A method of separating and recovering communications signals 

2 received in the presence of at least one interfering signal, comprising the steps of: 

3 receiving a desired communication signal at an antenna array, from a 

4 communication signal source; 

5 simultaneously receiving at the antenna array interfering signals from at 

6 least one interfering signal source at a transmitter, which radiates energy in the same 

7 frequency band as the desired received communication signal; 

8 separating and recovering the desired communication signal by using 

9 cumulant-based processing and without knowledge of the geometry of the antenna array 

10 or the nature of the interfering signal; and 

11 outputting the desired communication signal and discarding the 

12 recovered interfering signals from the at least one relatively strong transmitter. 

1 92. A method of radio direction finding (DF) using a subarray of 

2 calibrated antennas, the method comprising the steps of: 

3 receiving signals from multiple sources, at an antenna array of which 

4 only a small number of antenna elements are calibrated; 
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5 separating the signals using a cumulant recovery (CURE) system to 

6 generate the separated signals and estimates of their generalized steering vectors; and 

7 processing the estimated generalized steering vectors and signals from 

8 the calibrated antenna elements, to obtain accurate signal directions for the multiple 

9 sources. 

1 93. A method for extending the effective dynamic range of a radio 

2 receiver system, comprising the steps of: 

3 receiving a signal of interest through an antenna array; 

4 subjecting the received signal to analog and analog-to-digital processing, 

5 which results in adding products of distortion to the received signal; and 

6 eliminating the principal products of distortion in a cumulant recovery 

7 processing system, and thereby extending the effective dynamic range of the receiver. 

1 94. A method for separating data recorded on adjacent, closely spaced 

2 tracks on a recording medium, the method comprising the steps of: 

3 sensing information recorded on multiple adjacent tracks on a recording 

4 medium, by means of an array of sensors spanning more than one recording track; and 

5 separating and recovering the information derived from each track, 

6 using a cumulant recovery processing system to process the information sensed by the 

7 array of sensors; 

8 whereby information can be recorded at higher densities and still 

9 separated and recovered without improving the accuracy of sensor positioning. 

1 95. Apparatus for reading data recorded on adjacent, closely spaced 

2 tracks on a recording medium, the apparatus comprising: 

3 an array of sensors (402) spanning more than one recording track on the 

4 recording medium; and 

5 a cumulant recovery processing system (404) for separating and 

6 recovering information derived from each track by the sensors, whereby information 
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7 can be recorded at high densities and still separated and recovered without the need for 

8 improving sensor positioning accuracy. 



1 96. A method of complex phase equalization for use in a communication 

2 system using two-dimensional signal constellations, the method comprising: 

3 receiving and downconverting a two-dimensional communication signal, 

4 to generate in-phase (I) and quadrature (Q) components that have been phase-rotated by 

5 an unknown amount during propagation from a transmitter; 

6 processing the I and Q signals in a cumulant recovery (CURE) 

7 processing system, to obtain phase correction of the I and Q signals prior to signal 

8 demodulation! and 

9 demodulating the two-dimensional communication signal after the 

10 foregoing processing step, wherein phase correction is effected without regard to 

1 1 modulation type and independently of the step of demodulating. 

1 97. Complex phase equalizer apparatus for use in a communication 

2 system using two-dimensional signal constellations, the apparatus comprising: 

3 a receiver (416) for receiving a two-dimensional communication signal 

4 (418) and generating in-phase (I) and quadrature (Q) components, wherein the I and Q 

5 components are subject to phase rotation by an unknown angle; 

6 a cumulant recovery (CURE) processing system (420) connected to 

7 receive the I and Q components from the receiver wherein the I and Q signals received 

8 by the CURE processing system are each a linear combination of two independent 

9 source signals, which are the I and Q signals prior to phase rotation, and wherein the 

10 CURE processing system derives the two independent source signals and effectively 

1 1 compensates for the phase rotation of the I and Q signals; and 

12 a demodulator (422) connected to receive phase-corrected I and Q 

13 signals from the CURE processing system, wherein the CURE processing system 

14 effects phase correction of the communication signals prior to demodulation and 

15 independently of the demodulation type and the demodulation process. 
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DETECTION OF CHANGES IN SOURCE NUMBER 



COMPARE THE PREVIOUS BLOCK P e WITH 
CURRENT BLOCK P e : 

1. FOR THE INITIAL BLOCK, LET FLAG=0. 

2. FOR CONSEQUENT BLOCKS, 

a) IF CURRENT P e = PREVIOUS P e , 
THEN, FLAG=0. 

b) IF CURRENT P e > PREVIOUS P e , 
THEN, FLAG=1 (NEW SOURCE ON). 

c) IF CURRENT P e < PREVIOUS P e , 
THEN, FUG=2 (SOURCE OFF). 
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PORT ALLOCATION 

(A) IF FLAG=0. DO NOT MODIFY THE CAPTURE 
STRENGTH LIST. 

(B) IF FLAG=1. THEN FOR THE PORTS 
IN THE PRIORITY LIST: 

1. NORMALIZE THE STEERING VECTOR 
ESTIMATES BY THEIR NORM. 

2. PROJECT NORMALIZED STEERING VECTORS 
ONTO THE CURRENT NOISE SUBSPACE. 

3. DECLARE THE PORT WHOSE STEERING 
VECTOR HAS THE MINIMUM LEAK TO THE 
CURRENT NOISE SUBSPACE AS ACTIVE: 
OVERWRITE ITS CAPTURE STRENGTH AS 2 X 
MIN. 

(C) IF FLAG=2 , THEN FOR THE FIRST MIN 
(P e + 1, L) PORTS OF THE PRIORITY LIST 

DO STEPS 1 & 2 AS DONE FOR (B). THEN 
DECLARE THE PORT WHOSE STEERING VECTOR 
HAS THE MAXIMUM LEAK TO THE CURRENT 
NOISE SUBSPACE AS INACTIVE: OVERWRITE ITS 
CAPTURE STRENGTH AS MIN. 
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ADAPTATION FLAGS 

ADAPTATION FLAG IS ON FOR THE 
FIRST P e PORTS OF THE PRIORITY LIST. 
EXAMPLE: FPR 2 SOURCES, 
PORT 1 AND 4 ARE ACTIVATED. 
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PRIORITY LIST DETERMINATION 

PUT THE CAPTURE STRENGTH LIST 
IN DESCENDING ORDER. INDICES OF 
ORDERING YIELD THE PRIORITY LIST. 
EXAMPLE: LET CAPTURE STRENGTH 
LIST BE [0.3,1,2,0.4,0.3] FOR A FIVE 
PORT SUSTEM. THEN, THE PRIORITY 
LIST IS: [3,2,4,1,5] (THOUGH PORT 5 
AND PORT 1 CAPTURE STRENGTHS ARE 
IDENTICAL, FIRST PORT IS PUT AT A 
HIGHER PRIORITY). 
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(A) IF THE INPUT IS 1 (i.e., THE PORT 
WAS ACTIVE IN THE PREVIOUS BLOCK), 
THEN, STORE THE STEERING VECTOR 
ESTIMATE FROM THE TWO BLOCKS 
BEFORE: 

a fc (m) = o k (m-2) 

(B) IF THE INPUT IS 0, THEN THE PORT 
WAS ALREADY INACTIVE IN THE PREVIOUS 
BLOCK. THEREFORE STORE a k FROM 
THE PREVIOUS BLOCK: 

Q k (m) = dfc(m-1) 
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CUMULANT MATRIX COMPUTER 



1. CALCULATES A CUMULANT MATRIX C OF SIZE 
P 2 BY P 2 , FOR PREPROCESSED MEASUREMENTS. 

2. USES ALL OF SYMMETRY PROPERTIES OF 
CUMULANTS FOR REDUCING COMPUTATIONS. 
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MULTIPLE PORT SIGNAL RECOVERY 

1. USE PREVIOUS BLOCK STEERING ESTIMATES AND 
THE CURRENT EIGENSTRUCTURE TO FIND THE 
EIGENVECTORS AT C BY THE POWER METHOD. 

2. USE THE EIGENSTRUCTURE AND ESTIMATED 
EIGENVECTORS OF C TO ESTIMATE THE 
CURRENT STEERING VECTORS. 

3. MATCH THE CURRENT STEERING VECTORS WITH 
THE PREVIOUS BLOCK STEERING VECTORS AND 
IMPOSE WAVEFORM CONTINUITY CONSTRAINTS 
TO DETERMINE WEIGHT VECTORS FOR CURRENT 
BLOCK OF DATA. 

4. BEAMFORM TO EXTRACT MULTIPLE SOURCE 
WAVEFORMS. 
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